--- /dev/null
+Copyright (c) 2006 Bob Ippolito
+
+Permission is hereby granted, free of charge, to any person obtaining a copy of
+this software and associated documentation files (the "Software"), to deal in
+the Software without restriction, including without limitation the rights to
+use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies
+of the Software, and to permit persons to whom the Software is furnished to do
+so, subject to the following conditions:
+
+The above copyright notice and this permission notice shall be included in all
+copies or substantial portions of the Software.
+
+THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
+FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
+AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
+LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
+OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
+SOFTWARE.
--- /dev/null
+Metadata-Version: 1.0
+Name: simplejson
+Version: 1.7.1
+Summary: Simple, fast, extensible JSON encoder/decoder for Python
+Home-page: http://undefined.org/python/#simplejson
+Author: Bob Ippolito
+Author-email: bob@redivi.com
+License: MIT License
+Description:
+ simplejson is a simple, fast, complete, correct and extensible
+ JSON <http://json.org> encoder and decoder for Python 2.3+. It is
+ pure Python code with no dependencies, but includes an optional C
+ extension for a serious speed boost.
+
+ simplejson was formerly known as simple_json, but changed its name to
+ comply with PEP 8 module naming guidelines.
+
+ The encoder may be subclassed to provide serialization in any kind of
+ situation, without any special support by the objects to be serialized
+ (somewhat like pickle).
+
+ The decoder can handle incoming JSON strings of any specified encoding
+ (UTF-8 by default).
+
+Platform: any
+Classifier: Intended Audience :: Developers
+Classifier: License :: OSI Approved :: MIT License
+Classifier: Programming Language :: Python
+Classifier: Topic :: Software Development :: Libraries :: Python Modules
--- /dev/null
+<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">
+<HTML>
+
+ <HEAD><META CONTENT="text/html; charset=utf-8" HTTP-EQUIV="Content-Type">
+ <TITLE>simplejson.JSONDecoder -- Simple JSON &lt;<a class="reference" href="http://json.org">http://json.org</a>&gt; decoder</TITLE>
+ <LINK HREF="layout.css" TYPE="text/css" REL="stylesheet">
+ </HEAD>
+ <BODY>
+ <DIV ID="page">
+
+ <DIV ID="top-nav">
+ <H1 ID="doc-title"><A HREF="index.html" REL="index">simplejson 1.7.1</A></H1>
+ <DIV CLASS="online-navigation">
+ <A HREF="index.html" REL="index">index</A>
+ <SPAN ID="nav-docs">
+
+ </SPAN>
+
+
+
+ <BR>
+
+ <A HREF="module-simplejson.html" TITLE="simplejson reference">
+ simplejson
+ </A>
+
+
+
+ <A HREF="class-simplejson.JSONDecoder.html">details</A>
+
+ <A HREF="class-simplejson.JSONDecoder-index.html">
+ tree
+ </A>
+
+
+ </DIV>
+ </DIV>
+
+ <DIV ID="main-content">
+
+ <H1 CLASS="pudge-member-page-heading">
+ <TT>JSONDecoder</TT>
+ </H1>
+ <H4 CLASS="pudge-member-page-subheading">
+ Simple JSON <<A HREF="http://json.org" CLASS="reference">http://json.org</A>> decoder
+ </H4>
+ <P CLASS="pudge-member-parent-link">
+ <SMALL>
+ The JSONDecoder class is accessible via the
+ <A HREF="module-simplejson.html">
+ <TT>simplejson</TT>
+ </A> module.
+ </SMALL>
+ </P>
+ <DIV ID="pudge-section-nav">
+ <UL>
+ <LI>
+
+ <SPAN CLASS="pudge-missing-section-link">
+ Attributes
+ </SPAN>
+ </LI><LI>
+ <A HREF="#methods" CLASS="pudge-section-link">
+ Methods (3)
+ </A>
+
+ </LI>
+
+ <LI>
+ <A HREF="simplejson/decoder.py.html?f=196&l=272#196" CLASS="pudge-section-link">
+ Source
+ </A>
+ </LI>
+ </UL>
+ </DIV>
+ <DIV STYLE="clear: left"></DIV>
+ <DIV CLASS="rst pudge-module-doc">
+ <P>Performs the following translations in decoding:</P>
+<TABLE BORDER="1" CLASS="docutils">
+<COLGROUP>
+<COL WIDTH="44%">
+<COL WIDTH="56%">
+</COLGROUP>
+<THEAD VALIGN="bottom">
+<TR><TH CLASS="head">JSON</TH>
+<TH CLASS="head">Python</TH>
+</TR>
+</THEAD>
+<TBODY VALIGN="top">
+<TR><TD>object</TD>
+<TD>dict</TD>
+</TR>
+<TR><TD>array</TD>
+<TD>list</TD>
+</TR>
+<TR><TD>string</TD>
+<TD>unicode</TD>
+</TR>
+<TR><TD>number (int)</TD>
+<TD>int, long</TD>
+</TR>
+<TR><TD>number (real)</TD>
+<TD>float</TD>
+</TR>
+<TR><TD>true</TD>
+<TD>True</TD>
+</TR>
+<TR><TD>false</TD>
+<TD>False</TD>
+</TR>
+<TR><TD>null</TD>
+<TD>None</TD>
+</TR>
+</TBODY>
+</TABLE>
+<P>It also understands <TT CLASS="docutils literal"><SPAN CLASS="pre">NaN</SPAN></TT>, <TT CLASS="docutils literal"><SPAN CLASS="pre">Infinity</SPAN></TT>, and <TT CLASS="docutils literal"><SPAN CLASS="pre">-Infinity</SPAN></TT> as
+their corresponding <TT CLASS="docutils literal"><SPAN CLASS="pre">float</SPAN></TT> values, which is outside the JSON spec.</P>
+
+ </DIV>
+
+ <HR>
+
+
+ <A NAME="methods"></A>
+ <H2>Methods</H2>
+ <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.JSONDecoder.html#__init__" CLASS="pudge-obj-link">__init__</A>(self, encoding=None, object_hook=None)</TT>
+ <A HREF="simplejson/decoder.py.html?f=229&l=245#229" TITLE="View Source">...</A>
+ </H4>
+ <DIV CLASS="pudge-section rst">
+
+ <P CLASS="pudge-member-blurb">
+ <TT CLASS="docutils literal"><SPAN CLASS="pre">encoding</SPAN></TT> determines the encoding used to interpret any <TT CLASS="docutils literal"><SPAN CLASS="pre">str</SPAN></TT>
+objects decoded by this instance (utf-8 by default). It has no
+effect when decoding <TT CLASS="docutils literal"><SPAN CLASS="pre">unicode</SPAN></TT> objects.
+ </P>
+ <P>Note that currently only encodings that are a superset of ASCII work,
+strings of other encodings should be passed in as <TT CLASS="docutils literal"><SPAN CLASS="pre">unicode</SPAN></TT>.</P>
+<P><TT CLASS="docutils literal"><SPAN CLASS="pre">object_hook</SPAN></TT>, if specified, will be called with the result
+of every JSON object decoded and its return value will be used in
+place of the given <TT CLASS="docutils literal"><SPAN CLASS="pre">dict</SPAN></TT>. This can be used to provide custom
+deserializations (e.g. to support JSON-RPC class hinting).</P>
+
+
+ </DIV>
+ </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 0x13244a0>)</TT>
+ <A HREF="simplejson/decoder.py.html?f=246&l=256#246" TITLE="View Source">...</A>
+ </H4>
+ <DIV CLASS="pudge-section rst">
+
+ <P CLASS="pudge-member-blurb">
+ Return the Python representation of <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)
+ </P>
+
+
+ </DIV>
+ </DIV><DIV CLASS="pudge-member routine alias">
+ <A NAME="raw_decode"></A>
+ <H4 CLASS="pudge-member-name"><SPAN CLASS="prefix">f</SPAN>
+ <TT><A HREF="class-simplejson.JSONDecoder.html#raw_decode" CLASS="pudge-obj-link">raw_decode</A>(self, s, **kw)</TT>
+ <A HREF="simplejson/decoder.py.html?f=257&l=272#257" TITLE="View Source">...</A>
+ </H4>
+ <DIV CLASS="pudge-section rst">
+
+ <P CLASS="pudge-member-blurb">
+ Decode a JSON document from <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> beginning
+with a JSON document) and return a 2-tuple of the Python
+representation and the index in <TT CLASS="docutils literal"><SPAN CLASS="pre">s</SPAN></TT> where the document ended.
+ </P>
+ <P>This can be used to decode a JSON document from a string that may
+have extraneous data at the end.</P>
+
+
+ </DIV>
+ </DIV>
+
+
+
+ <P>
+ <SMALL>
+
+
+ See
+ <A HREF="simplejson/decoder.py.html?f=196&l=272#196" TITLE="simplejson/decoder.py:196">the source</A>
+ for more information.
+ </SMALL>
+ </P>
+
+</DIV>
+
+ <DIV ID="footer">
+
+ <P ID="pudge">
+ Built with
+ <A HREF="http://lesscode.org/projects/pudge/">
+ Pudge/0.1.3</A>
+ </P>
+
+
+ </DIV>
+ </DIV>
+ </BODY>
+
+</HTML>
\ No newline at end of file
--- /dev/null
+<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">
+<HTML>
+
+ <HEAD><META CONTENT="text/html; charset=utf-8" HTTP-EQUIV="Content-Type">
+ <TITLE>simplejson.JSONEncoder -- Extensible JSON &lt;<a class="reference" href="http://json.org">http://json.org</a>&gt; encoder for Python data structures.</TITLE>
+ <LINK HREF="layout.css" TYPE="text/css" REL="stylesheet">
+ </HEAD>
+ <BODY>
+ <DIV ID="page">
+
+ <DIV ID="top-nav">
+ <H1 ID="doc-title"><A HREF="index.html" REL="index">simplejson 1.7.1</A></H1>
+ <DIV CLASS="online-navigation">
+ <A HREF="index.html" REL="index">index</A>
+ <SPAN ID="nav-docs">
+
+ </SPAN>
+
+
+
+ <BR>
+
+ <A HREF="module-simplejson.html" TITLE="simplejson reference">
+ simplejson
+ </A>
+
+
+
+ <A HREF="class-simplejson.JSONEncoder.html">details</A>
+
+ <A HREF="class-simplejson.JSONEncoder-index.html">
+ tree
+ </A>
+
+
+ </DIV>
+ </DIV>
+
+ <DIV ID="main-content">
+
+ <H1 CLASS="pudge-member-page-heading">
+ <TT>JSONEncoder</TT>
+ </H1>
+ <H4 CLASS="pudge-member-page-subheading">
+ Extensible JSON <<A HREF="http://json.org" CLASS="reference">http://json.org</A>> encoder for Python data structures.
+ </H4>
+ <P CLASS="pudge-member-parent-link">
+ <SMALL>
+ The JSONEncoder class is accessible via the
+ <A HREF="module-simplejson.html">
+ <TT>simplejson</TT>
+ </A> module.
+ </SMALL>
+ </P>
+ <DIV ID="pudge-section-nav">
+ <UL>
+ <LI>
+
+ <SPAN CLASS="pudge-missing-section-link">
+ Attributes
+ </SPAN>
+ </LI><LI>
+ <A HREF="#methods" CLASS="pudge-section-link">
+ Methods (4)
+ </A>
+
+ </LI>
+
+ <LI>
+ <A HREF="simplejson/encoder.py.html?f=80&l=370#80" CLASS="pudge-section-link">
+ Source
+ </A>
+ </LI>
+ </UL>
+ </DIV>
+ <DIV STYLE="clear: left"></DIV>
+ <DIV CLASS="rst pudge-module-doc">
+ <P>Supports the following objects and types by default:</P>
+<TABLE BORDER="1" CLASS="docutils">
+<COLGROUP>
+<COL WIDTH="56%">
+<COL WIDTH="44%">
+</COLGROUP>
+<THEAD VALIGN="bottom">
+<TR><TH CLASS="head">Python</TH>
+<TH CLASS="head">JSON</TH>
+</TR>
+</THEAD>
+<TBODY VALIGN="top">
+<TR><TD>dict</TD>
+<TD>object</TD>
+</TR>
+<TR><TD>list, tuple</TD>
+<TD>array</TD>
+</TR>
+<TR><TD>str, unicode</TD>
+<TD>string</TD>
+</TR>
+<TR><TD>int, long, float</TD>
+<TD>number</TD>
+</TR>
+<TR><TD>True</TD>
+<TD>true</TD>
+</TR>
+<TR><TD>False</TD>
+<TD>false</TD>
+</TR>
+<TR><TD>None</TD>
+<TD>null</TD>
+</TR>
+</TBODY>
+</TABLE>
+<P>To extend this to recognize other objects, subclass and implement a
+<TT CLASS="docutils literal"><SPAN CLASS="pre">.default()</SPAN></TT> method with another method that returns a serializable
+object for <TT CLASS="docutils literal"><SPAN CLASS="pre">o</SPAN></TT> if possible, otherwise it should call the superclass
+implementation (to raise <TT CLASS="docutils literal"><SPAN CLASS="pre">TypeError</SPAN></TT>).</P>
+
+ </DIV>
+
+ <HR>
+
+
+ <A NAME="methods"></A>
+ <H2>Methods</H2>
+ <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=112&l=164#112" TITLE="View Source">...</A>
+ </H4>
+ <DIV CLASS="pudge-section rst">
+
+ <P CLASS="pudge-member-blurb">
+ Constructor for JSONEncoder, with sensible defaults.
+ </P>
+ <P>If skipkeys is False, then it is a TypeError to attempt
+encoding of keys that are not str, int, long, float or None. If
+skipkeys is True, such items are simply skipped.</P>
+<P>If ensure_ascii is True, the output is guaranteed to be str
+objects with all incoming unicode characters escaped. If
+ensure_ascii is false, the output will be unicode object.</P>
+<P>If check_circular is True, then lists, dicts, and custom encoded
+objects will be checked for circular references during encoding to
+prevent an infinite recursion (which would cause an OverflowError).
+Otherwise, no such check takes place.</P>
+<P>If allow_nan is True, then NaN, Infinity, and -Infinity will be
+encoded as such. This behavior is not JSON specification compliant,
+but is consistent with most JavaScript based encoders and decoders.
+Otherwise, it will be a ValueError to encode such floats.</P>
+<P>If sort_keys is True, then the output of dictionaries will be
+sorted by key; this is useful for regression tests to ensure
+that JSON serializations can be compared on a day-to-day basis.</P>
+<P>If indent is a non-negative integer, then JSON array
+elements and object members will be pretty-printed with that
+indent level. An indent level of 0 will only insert newlines.
+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 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>
+
+
+ </DIV>
+ </DIV><DIV CLASS="pudge-member routine alias">
+ <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=314&l=333#314" TITLE="View Source">...</A>
+ </H4>
+ <DIV CLASS="pudge-section rst">
+
+ <P CLASS="pudge-member-blurb">
+ Implement this method in a subclass such that it returns
+a serializable object for <TT CLASS="docutils literal"><SPAN CLASS="pre">o</SPAN></TT>, or calls the base implementation
+(to raise a <TT CLASS="docutils literal"><SPAN CLASS="pre">TypeError</SPAN></TT>).
+ </P>
+ <P>For example, to support arbitrary iterators, you could
+implement default like this:</P>
+<PRE CLASS="literal-block">
+def default(self, o):
+ try:
+ iterable = iter(o)
+ except TypeError:
+ pass
+ else:
+ return list(iterable)
+ return JSONEncoder.default(self, o)
+</PRE>
+
+
+ </DIV>
+ </DIV><DIV CLASS="pudge-member routine alias">
+ <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=334&l=354#334" TITLE="View Source">...</A>
+ </H4>
+ <DIV CLASS="pudge-section rst">
+
+ <P CLASS="pudge-member-blurb">
+ Return a JSON string representation of a Python data structure.
+ </P>
+ <PRE CLASS="doctest-block">
+>>> JSONEncoder().encode({"foo": ["bar", "baz"]})
+'{"foo":["bar", "baz"]}'
+</PRE>
+
+
+ </DIV>
+ </DIV><DIV CLASS="pudge-member routine alias">
+ <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=355&l=370#355" TITLE="View Source">...</A>
+ </H4>
+ <DIV CLASS="pudge-section rst">
+
+ <P CLASS="pudge-member-blurb">
+ Encode the given object and yield each string
+representation as available.
+ </P>
+ <P>For example:</P>
+<PRE CLASS="literal-block">
+for chunk in JSONEncoder().iterencode(bigobject):
+ mysocket.write(chunk)
+</PRE>
+
+
+ </DIV>
+ </DIV>
+
+
+
+ <P>
+ <SMALL>
+
+
+ See
+ <A HREF="simplejson/encoder.py.html?f=80&l=370#80" TITLE="simplejson/encoder.py:80">the source</A>
+ for more information.
+ </SMALL>
+ </P>
+
+</DIV>
+
+ <DIV ID="footer">
+
+ <P ID="pudge">
+ Built with
+ <A HREF="http://lesscode.org/projects/pudge/">
+ Pudge/0.1.3</A>
+ </P>
+
+
+ </DIV>
+ </DIV>
+ </BODY>
+
+</HTML>
\ No newline at end of file
--- /dev/null
+(function () {
+ var href = document.location.href;
+ if (href.indexOf("file:") == 0 || !document.getElementsByTagName) return;
+ var _old_onload = window.onload;
+ window.onload = function () {
+ if (_old_onload) _old_onload.call(this);
+ _old_onload = null;
+ var anchors = document.getElementsByTagName('A');
+ var class_re = /\blines-(\d+)-(\d+)\b/;
+ var hash_re = /#.*$/;
+ for (var i = 0; i < anchors.length; i++) {
+ var anchor = anchors[i];
+ var found = anchor.className.match(class_re);
+ if (!found) continue;
+ href = anchor.href;
+ var hashidx = href.indexOf("#");
+ if (hashidx == -1) hashidx = href.length;
+ anchor.href = (href.substring(0, hashidx) + "?f=" + found[1] +
+ "&l=" + found[2] + href.substring(hashidx, href.length));
+ }
+ }
+})();
--- /dev/null
+<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">
+<HTML>
+
+ <HEAD><META CONTENT="text/html; charset=utf-8" HTTP-EQUIV="Content-Type">
+ <TITLE>simplejson -- A simple, fast, extensible JSON encoder and decoder</TITLE>
+ <LINK HREF="layout.css" TYPE="text/css" REL="stylesheet">
+ </HEAD>
+ <BODY>
+ <DIV ID="page">
+
+ <DIV ID="top-nav">
+ <H1 ID="doc-title"><A HREF="index.html" REL="index">simplejson 1.7.1</A></H1>
+ <DIV CLASS="online-navigation">
+ <A HREF="index.html" REL="index">index</A>
+ <SPAN ID="nav-docs">
+
+ </SPAN>
+
+
+
+ <BR>
+
+ <A HREF="module-simplejson.html" TITLE="simplejson reference">
+ simplejson
+ </A>
+
+
+
+ <A HREF="module-simplejson.html">details</A>
+
+ <A HREF="module-simplejson-index.html">
+ tree
+ </A>
+
+
+ </DIV>
+ </DIV>
+
+ <DIV ID="main-content">
+
+ <H1 CLASS="pudge-member-page-heading">
+ <TT>simplejson</TT>
+ </H1>
+ <H4 CLASS="pudge-member-page-subheading">
+ A simple, fast, extensible JSON encoder and decoder
+ </H4>
+
+ <DIV ID="pudge-section-nav">
+ <UL>
+ <LI>
+
+ <SPAN CLASS="pudge-missing-section-link">
+ Attributes
+ </SPAN>
+ </LI><LI>
+ <A HREF="#functions" CLASS="pudge-section-link">
+ Functions (4)
+ </A>
+
+ </LI><LI>
+ <A HREF="#classes" CLASS="pudge-section-link">
+ Classes (2)
+ </A>
+
+ </LI><LI>
+
+ <SPAN CLASS="pudge-missing-section-link">
+ Modules
+ </SPAN>
+ </LI>
+ <LI>
+ <A HREF="module-simplejson-index.html" CLASS="pudge-section-link">
+ Index
+ </A>
+ </LI>
+ <LI>
+ <A HREF="simplejson/__init__.py.html" CLASS="pudge-section-link">
+ Source
+ </A>
+ </LI>
+ </UL>
+ </DIV>
+ <DIV STYLE="clear: left"></DIV>
+ <DIV CLASS="rst pudge-module-doc">
+ <P>JSON (JavaScript Object Notation) <<A HREF="http://json.org" CLASS="reference">http://json.org</A>> is a subset of
+JavaScript syntax (ECMA-262 3rd edition) used as a lightweight data
+interchange format.</P>
+<P>simplejson exposes an API familiar to uses of the standard library
+marshal and pickle modules.</P>
+<P>Encoding basic Python object hierarchies:</P>
+<PRE CLASS="literal-block">
+>>> import simplejson
+>>> simplejson.dumps(['foo', {'bar': ('baz', None, 1.0, 2)}])
+'["foo", {"bar": ["baz", null, 1.0, 2]}]'
+>>> print simplejson.dumps("\"foo\bar")
+"\"foo\bar"
+>>> print simplejson.dumps(u'\u1234')
+"\u1234"
+>>> print simplejson.dumps('\\')
+"\\"
+>>> print simplejson.dumps({"c": 0, "b": 0, "a": 0}, sort_keys=True)
+{"a": 0, "b": 0, "c": 0}
+>>> from StringIO import StringIO
+>>> io = StringIO()
+>>> simplejson.dump(['streaming API'], io)
+>>> io.getvalue()
+'["streaming API"]'
+</PRE>
+<P>Compact encoding:</P>
+<PRE CLASS="literal-block">
+>>> import simplejson
+>>> simplejson.dumps([1,2,3,{'4': 5, '6': 7}], separators=(',',':'))
+'[1,2,3,{"4":5,"6":7}]'
+</PRE>
+<P>Pretty printing:</P>
+<PRE CLASS="literal-block">
+>>> import simplejson
+>>> print simplejson.dumps({'4': 5, '6': 7}, sort_keys=True, indent=4)
+{
+ "4": 5,
+ "6": 7
+}
+</PRE>
+<P>Decoding JSON:</P>
+<PRE CLASS="literal-block">
+>>> import simplejson
+>>> simplejson.loads('["foo", {"bar":["baz", null, 1.0, 2]}]')
+[u'foo', {u'bar': [u'baz', None, 1.0, 2]}]
+>>> simplejson.loads('"\\"foo\\bar"')
+u'"foo\x08ar'
+>>> from StringIO import StringIO
+>>> io = StringIO('["streaming API"]')
+>>> simplejson.load(io)
+[u'streaming API']
+</PRE>
+<P>Specializing JSON object decoding:</P>
+<PRE CLASS="literal-block">
+>>> import simplejson
+>>> def as_complex(dct):
+... if '__complex__' in dct:
+... return complex(dct['real'], dct['imag'])
+... return dct
+...
+>>> simplejson.loads('{"__complex__": true, "real": 1, "imag": 2}',
+... object_hook=as_complex)
+(1+2j)
+</PRE>
+<P>Extending JSONEncoder:</P>
+<PRE CLASS="literal-block">
+>>> import simplejson
+>>> class ComplexEncoder(simplejson.JSONEncoder):
+... def default(self, obj):
+... if isinstance(obj, complex):
+... return [obj.real, obj.imag]
+... return simplejson.JSONEncoder.default(self, obj)
+...
+>>> dumps(2 + 1j, cls=ComplexEncoder)
+'[2.0, 1.0]'
+>>> ComplexEncoder().encode(2 + 1j)
+'[2.0, 1.0]'
+>>> list(ComplexEncoder().iterencode(2 + 1j))
+['[', '2.0', ', ', '1.0', ']']
+</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>
+
+ </DIV>
+
+ <HR>
+
+
+ <A NAME="functions"></A>
+ <H2>Functions</H2>
+ <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=108&l=164#108" TITLE="View Source">...</A>
+ </H4>
+ <DIV CLASS="pudge-section rst">
+
+ <P CLASS="pudge-member-blurb">
+ 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).
+ </P>
+ <P>If <TT CLASS="docutils literal"><SPAN CLASS="pre">skipkeys</SPAN></TT> is <TT CLASS="docutils literal"><SPAN CLASS="pre">True</SPAN></TT> then <TT CLASS="docutils literal"><SPAN CLASS="pre">dict</SPAN></TT> keys that are not basic types
+(<TT CLASS="docutils literal"><SPAN CLASS="pre">str</SPAN></TT>, <TT CLASS="docutils literal"><SPAN CLASS="pre">unicode</SPAN></TT>, <TT CLASS="docutils literal"><SPAN CLASS="pre">int</SPAN></TT>, <TT CLASS="docutils literal"><SPAN CLASS="pre">long</SPAN></TT>, <TT CLASS="docutils literal"><SPAN CLASS="pre">float</SPAN></TT>, <TT CLASS="docutils literal"><SPAN CLASS="pre">bool</SPAN></TT>, <TT CLASS="docutils literal"><SPAN CLASS="pre">None</SPAN></TT>)
+will be skipped instead of raising a <TT CLASS="docutils literal"><SPAN CLASS="pre">TypeError</SPAN></TT>.</P>
+<P>If <TT CLASS="docutils literal"><SPAN CLASS="pre">ensure_ascii</SPAN></TT> is <TT CLASS="docutils literal"><SPAN CLASS="pre">False</SPAN></TT>, then the some chunks written to <TT CLASS="docutils literal"><SPAN CLASS="pre">fp</SPAN></TT>
+may be <TT CLASS="docutils literal"><SPAN CLASS="pre">unicode</SPAN></TT> instances, subject to normal Python <TT CLASS="docutils literal"><SPAN CLASS="pre">str</SPAN></TT> to
+<TT CLASS="docutils literal"><SPAN CLASS="pre">unicode</SPAN></TT> coercion rules. Unless <TT CLASS="docutils literal"><SPAN CLASS="pre">fp.write()</SPAN></TT> explicitly
+understands <TT CLASS="docutils literal"><SPAN CLASS="pre">unicode</SPAN></TT> (as in <TT CLASS="docutils literal"><SPAN CLASS="pre">codecs.getwriter()</SPAN></TT>) this is likely
+to cause an error.</P>
+<P>If <TT CLASS="docutils literal"><SPAN CLASS="pre">check_circular</SPAN></TT> is <TT CLASS="docutils literal"><SPAN CLASS="pre">False</SPAN></TT>, then the circular reference check
+for container types will be skipped and a circular reference will
+result in an <TT CLASS="docutils literal"><SPAN CLASS="pre">OverflowError</SPAN></TT> (or worse).</P>
+<P>If <TT CLASS="docutils literal"><SPAN CLASS="pre">allow_nan</SPAN></TT> is <TT CLASS="docutils literal"><SPAN CLASS="pre">False</SPAN></TT>, then it will be a <TT CLASS="docutils literal"><SPAN CLASS="pre">ValueError</SPAN></TT> to
+serialize out of range <TT CLASS="docutils literal"><SPAN CLASS="pre">float</SPAN></TT> values (<TT CLASS="docutils literal"><SPAN CLASS="pre">nan</SPAN></TT>, <TT CLASS="docutils literal"><SPAN CLASS="pre">inf</SPAN></TT>, <TT CLASS="docutils literal"><SPAN CLASS="pre">-inf</SPAN></TT>)
+in strict compliance of the JSON specification, instead of using the
+JavaScript equivalents (<TT CLASS="docutils literal"><SPAN CLASS="pre">NaN</SPAN></TT>, <TT CLASS="docutils literal"><SPAN CLASS="pre">Infinity</SPAN></TT>, <TT CLASS="docutils literal"><SPAN CLASS="pre">-Infinity</SPAN></TT>).</P>
+<P>If <TT CLASS="docutils literal"><SPAN CLASS="pre">indent</SPAN></TT> is a non-negative integer, then JSON array elements and object
+members will be pretty-printed with that indent level. An indent level
+of 0 will only insert newlines. <TT CLASS="docutils literal"><SPAN CLASS="pre">None</SPAN></TT> is the most compact representation.</P>
+<P>If <TT CLASS="docutils literal"><SPAN CLASS="pre">separators</SPAN></TT> is an <TT CLASS="docutils literal"><SPAN CLASS="pre">(item_separator,</SPAN> <SPAN CLASS="pre">dict_separator)</SPAN></TT> tuple
+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>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>
+
+
+ </DIV>
+ </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=166&l=217#166" TITLE="View Source">...</A>
+ </H4>
+ <DIV CLASS="pudge-section rst">
+
+ <P CLASS="pudge-member-blurb">
+ 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>.
+ </P>
+ <P>If <TT CLASS="docutils literal"><SPAN CLASS="pre">skipkeys</SPAN></TT> is <TT CLASS="docutils literal"><SPAN CLASS="pre">True</SPAN></TT> then <TT CLASS="docutils literal"><SPAN CLASS="pre">dict</SPAN></TT> keys that are not basic types
+(<TT CLASS="docutils literal"><SPAN CLASS="pre">str</SPAN></TT>, <TT CLASS="docutils literal"><SPAN CLASS="pre">unicode</SPAN></TT>, <TT CLASS="docutils literal"><SPAN CLASS="pre">int</SPAN></TT>, <TT CLASS="docutils literal"><SPAN CLASS="pre">long</SPAN></TT>, <TT CLASS="docutils literal"><SPAN CLASS="pre">float</SPAN></TT>, <TT CLASS="docutils literal"><SPAN CLASS="pre">bool</SPAN></TT>, <TT CLASS="docutils literal"><SPAN CLASS="pre">None</SPAN></TT>)
+will be skipped instead of raising a <TT CLASS="docutils literal"><SPAN CLASS="pre">TypeError</SPAN></TT>.</P>
+<P>If <TT CLASS="docutils literal"><SPAN CLASS="pre">ensure_ascii</SPAN></TT> is <TT CLASS="docutils literal"><SPAN CLASS="pre">False</SPAN></TT>, then the return value will be a
+<TT CLASS="docutils literal"><SPAN CLASS="pre">unicode</SPAN></TT> instance subject to normal Python <TT CLASS="docutils literal"><SPAN CLASS="pre">str</SPAN></TT> to <TT CLASS="docutils literal"><SPAN CLASS="pre">unicode</SPAN></TT>
+coercion rules instead of being escaped to an ASCII <TT CLASS="docutils literal"><SPAN CLASS="pre">str</SPAN></TT>.</P>
+<P>If <TT CLASS="docutils literal"><SPAN CLASS="pre">check_circular</SPAN></TT> is <TT CLASS="docutils literal"><SPAN CLASS="pre">False</SPAN></TT>, then the circular reference check
+for container types will be skipped and a circular reference will
+result in an <TT CLASS="docutils literal"><SPAN CLASS="pre">OverflowError</SPAN></TT> (or worse).</P>
+<P>If <TT CLASS="docutils literal"><SPAN CLASS="pre">allow_nan</SPAN></TT> is <TT CLASS="docutils literal"><SPAN CLASS="pre">False</SPAN></TT>, then it will be a <TT CLASS="docutils literal"><SPAN CLASS="pre">ValueError</SPAN></TT> to
+serialize out of range <TT CLASS="docutils literal"><SPAN CLASS="pre">float</SPAN></TT> values (<TT CLASS="docutils literal"><SPAN CLASS="pre">nan</SPAN></TT>, <TT CLASS="docutils literal"><SPAN CLASS="pre">inf</SPAN></TT>, <TT CLASS="docutils literal"><SPAN CLASS="pre">-inf</SPAN></TT>) in
+strict compliance of the JSON specification, instead of using the
+JavaScript equivalents (<TT CLASS="docutils literal"><SPAN CLASS="pre">NaN</SPAN></TT>, <TT CLASS="docutils literal"><SPAN CLASS="pre">Infinity</SPAN></TT>, <TT CLASS="docutils literal"><SPAN CLASS="pre">-Infinity</SPAN></TT>).</P>
+<P>If <TT CLASS="docutils literal"><SPAN CLASS="pre">indent</SPAN></TT> is a non-negative integer, then JSON array elements and
+object members will be pretty-printed with that indent level. An indent
+level of 0 will only insert newlines. <TT CLASS="docutils literal"><SPAN CLASS="pre">None</SPAN></TT> is the most compact
+representation.</P>
+<P>If <TT CLASS="docutils literal"><SPAN CLASS="pre">separators</SPAN></TT> is an <TT CLASS="docutils literal"><SPAN CLASS="pre">(item_separator,</SPAN> <SPAN CLASS="pre">dict_separator)</SPAN></TT> tuple
+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>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>
+
+
+ </DIV>
+ </DIV><DIV CLASS="pudge-member routine ">
+ <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, **kw)</TT>
+ <A HREF="simplejson/__init__.py.html?f=220&l=242#220" TITLE="View Source">...</A>
+ </H4>
+ <DIV CLASS="pudge-section rst">
+
+ <P CLASS="pudge-member-blurb">
+ 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.
+ </P>
+ <P>If the contents of <TT CLASS="docutils literal"><SPAN CLASS="pre">fp</SPAN></TT> is encoded with an ASCII based encoding other
+than utf-8 (e.g. latin-1), then an appropriate <TT CLASS="docutils literal"><SPAN CLASS="pre">encoding</SPAN></TT> name must
+be specified. Encodings that are not ASCII based (such as UCS-2) are
+not allowed, and should be wrapped with
+<TT CLASS="docutils literal"><SPAN CLASS="pre">codecs.getreader(fp)(encoding)</SPAN></TT>, or simply decoded to a <TT CLASS="docutils literal"><SPAN CLASS="pre">unicode</SPAN></TT>
+object and passed to <TT CLASS="docutils literal"><SPAN CLASS="pre">loads()</SPAN></TT></P>
+<P><TT CLASS="docutils literal"><SPAN CLASS="pre">object_hook</SPAN></TT> is an optional function that will be called with the
+result of any object literal decode (a <TT CLASS="docutils literal"><SPAN CLASS="pre">dict</SPAN></TT>). The return value of
+<TT CLASS="docutils literal"><SPAN CLASS="pre">object_hook</SPAN></TT> will be used instead of the <TT CLASS="docutils literal"><SPAN CLASS="pre">dict</SPAN></TT>. This feature
+can be used to implement custom decoders (e.g. JSON-RPC class hinting).</P>
+<P>To use a custom <TT CLASS="docutils literal"><SPAN CLASS="pre">JSONDecoder</SPAN></TT> subclass, specify it with the <TT CLASS="docutils literal"><SPAN CLASS="pre">cls</SPAN></TT>
+kwarg.</P>
+
+
+ </DIV>
+ </DIV><DIV CLASS="pudge-member routine ">
+ <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, **kw)</TT>
+ <A HREF="simplejson/__init__.py.html?f=243&l=268#243" TITLE="View Source">...</A>
+ </H4>
+ <DIV CLASS="pudge-section rst">
+
+ <P CLASS="pudge-member-blurb">
+ 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.
+ </P>
+ <P>If <TT CLASS="docutils literal"><SPAN CLASS="pre">s</SPAN></TT> is a <TT CLASS="docutils literal"><SPAN CLASS="pre">str</SPAN></TT> instance and is encoded with an ASCII based encoding
+other than utf-8 (e.g. latin-1) then an appropriate <TT CLASS="docutils literal"><SPAN CLASS="pre">encoding</SPAN></TT> name
+must be specified. Encodings that are not ASCII based (such as UCS-2)
+are not allowed and should be decoded to <TT CLASS="docutils literal"><SPAN CLASS="pre">unicode</SPAN></TT> first.</P>
+<P><TT CLASS="docutils literal"><SPAN CLASS="pre">object_hook</SPAN></TT> is an optional function that will be called with the
+result of any object literal decode (a <TT CLASS="docutils literal"><SPAN CLASS="pre">dict</SPAN></TT>). The return value of
+<TT CLASS="docutils literal"><SPAN CLASS="pre">object_hook</SPAN></TT> will be used instead of the <TT CLASS="docutils literal"><SPAN CLASS="pre">dict</SPAN></TT>. This feature
+can be used to implement custom decoders (e.g. JSON-RPC class hinting).</P>
+<P>To use a custom <TT CLASS="docutils literal"><SPAN CLASS="pre">JSONDecoder</SPAN></TT> subclass, specify it with the <TT CLASS="docutils literal"><SPAN CLASS="pre">cls</SPAN></TT>
+kwarg.</P>
+
+
+ </DIV>
+ </DIV>
+
+
+ <A NAME="classes"></A>
+ <H2>Classes</H2>
+ <DIV CLASS="pudge-member class alias">
+ <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=80&l=370#80" CLASS="pudge-member-view-source" TITLE="View Source">...</A>
+ </H4>
+ <DIV CLASS="pudge-section rst">
+
+ <P CLASS="pudge-member-blurb">
+ Extensible JSON <<A HREF="http://json.org" CLASS="reference">http://json.org</A>> encoder for Python data structures.
+ </P>
+ <P>Supports the following objects and types by default:</P>
+<TABLE BORDER="1" CLASS="docutils">
+<COLGROUP>
+<COL WIDTH="56%">
+<COL WIDTH="44%">
+</COLGROUP>
+<THEAD VALIGN="bottom">
+<TR><TH CLASS="head">Python</TH>
+<TH CLASS="head">JSON</TH>
+</TR>
+</THEAD>
+<TBODY VALIGN="top">
+<TR><TD>dict</TD>
+<TD>object</TD>
+</TR>
+<TR><TD>list, tuple</TD>
+<TD>array</TD>
+</TR>
+<TR><TD>str, unicode</TD>
+<TD>string</TD>
+</TR>
+<TR><TD>int, long, float</TD>
+<TD>number</TD>
+</TR>
+<TR><TD>True</TD>
+<TD>true</TD>
+</TR>
+<TR><TD>False</TD>
+<TD>false</TD>
+</TR>
+<TR><TD>None</TD>
+<TD>null</TD>
+</TR>
+</TBODY>
+</TABLE>
+<P>To extend this to recognize other objects, subclass and implement a
+<TT CLASS="docutils literal"><SPAN CLASS="pre">.default()</SPAN></TT> method with another method that returns a serializable
+object for <TT CLASS="docutils literal"><SPAN CLASS="pre">o</SPAN></TT> if possible, otherwise it should call the superclass
+implementation (to raise <TT CLASS="docutils literal"><SPAN CLASS="pre">TypeError</SPAN></TT>).</P>
+
+
+
+ <P CLASS="note">
+ This class contains <A HREF="class-simplejson.JSONEncoder.html#members">
+ 5 members</A>.
+ </P>
+ </DIV>
+ </DIV><DIV CLASS="pudge-member class alias">
+ <H4 CLASS="pudge-member-name"><SPAN CLASS="prefix">C</SPAN>
+ <TT>
+ <A HREF="class-simplejson.JSONDecoder.html" CLASS="pudge-obj-link">JSONDecoder</A>(...)</TT>
+ <A HREF="simplejson/decoder.py.html?f=196&l=272#196" CLASS="pudge-member-view-source" TITLE="View Source">...</A>
+ </H4>
+ <DIV CLASS="pudge-section rst">
+
+ <P CLASS="pudge-member-blurb">
+ Simple JSON <<A HREF="http://json.org" CLASS="reference">http://json.org</A>> decoder
+ </P>
+ <P>Performs the following translations in decoding:</P>
+<TABLE BORDER="1" CLASS="docutils">
+<COLGROUP>
+<COL WIDTH="44%">
+<COL WIDTH="56%">
+</COLGROUP>
+<THEAD VALIGN="bottom">
+<TR><TH CLASS="head">JSON</TH>
+<TH CLASS="head">Python</TH>
+</TR>
+</THEAD>
+<TBODY VALIGN="top">
+<TR><TD>object</TD>
+<TD>dict</TD>
+</TR>
+<TR><TD>array</TD>
+<TD>list</TD>
+</TR>
+<TR><TD>string</TD>
+<TD>unicode</TD>
+</TR>
+<TR><TD>number (int)</TD>
+<TD>int, long</TD>
+</TR>
+<TR><TD>number (real)</TD>
+<TD>float</TD>
+</TR>
+<TR><TD>true</TD>
+<TD>True</TD>
+</TR>
+<TR><TD>false</TD>
+<TD>False</TD>
+</TR>
+<TR><TD>null</TD>
+<TD>None</TD>
+</TR>
+</TBODY>
+</TABLE>
+<P>It also understands <TT CLASS="docutils literal"><SPAN CLASS="pre">NaN</SPAN></TT>, <TT CLASS="docutils literal"><SPAN CLASS="pre">Infinity</SPAN></TT>, and <TT CLASS="docutils literal"><SPAN CLASS="pre">-Infinity</SPAN></TT> as
+their corresponding <TT CLASS="docutils literal"><SPAN CLASS="pre">float</SPAN></TT> values, which is outside the JSON spec.</P>
+
+
+
+ <P CLASS="note">
+ This class contains <A HREF="class-simplejson.JSONDecoder.html#members">
+ 4 members</A>.
+ </P>
+ </DIV>
+ </DIV>
+
+
+
+ <P>
+ <SMALL>
+
+
+ See
+ <A HREF="simplejson/__init__.py.html" TITLE="simplejson/__init__.py:0">the source</A>
+ for more information.
+ </SMALL>
+ </P>
+
+</DIV>
+
+ <DIV ID="footer">
+
+ <P ID="pudge">
+ Built with
+ <A HREF="http://lesscode.org/projects/pudge/">
+ Pudge/0.1.3</A>
+ </P>
+
+
+ </DIV>
+ </DIV>
+ </BODY>
+
+</HTML>
\ No newline at end of file
--- /dev/null
+@import url("pudge.css");
+
+/* Basic Layout
+---------------------------------- */
+
+body {
+ margin-left: 1em;
+ margin-right: 1em;
+ max-width: 50em;
+}
+body {
+ font-size: .80em;
+ color: #111;
+}
+div#main-content {
+ margin-left: 1em;
+ margin-right: 1em;
+ max-width: 47em;
+}
+
+/* Top Navigation
+----------------------------------- */
+
+div#top-nav {
+ background: #373;
+ padding: .3em .3em;
+ margin: 0;
+ margin-bottom: 1.5em;
+ font-size: 90%;
+}
+div#top-nav #doc-title {
+ font-size: 140%;
+ font-weight: bold;
+ margin: 0;
+ padding-top: .32em;
+ padding-right: 1em;
+ padding-left: .3em;
+ color: #9c9;
+ float: left;
+}
+div#top-nav a {
+ color: #6a6;
+ text-decoration: none;
+}
+div#top-nav .online-navigation a:hover,
+div#top-nav h1 a
+{
+ color: #9c9;
+}
+
+/* Footer
+----------------------------------- */
+
+div#footer {
+ text-align: right;
+ margin-top: 1.5em;
+ border-top: 1px solid #373;
+ padding-top: .5em;
+ font-size: 80%;
+ color: #666;
+}
+div#footer a {
+ color: #373;
+ text-decoration: none;
+}
+div#footer p {
+ margin: .2em 1em;
+}
+
+/* Basic Style
+----------------------------------- */
+h1, h2, h3, h4 {
+ margin: 1em auto;
+ font-family: 'Trebuchet MS', 'Verdana', Sans-serif;
+ color: #555;
+ font-weight: normal;
+}
+h1 { font-size: 200% }
+h2 { font-size: 170% }
+h3 { font-size: 150% }
+h4 { font-size: 120% }
+a:link { color: #060; font-weight: bold }
+a:visited { color: #060; text-decoration: none }
+hr { margin: auto 12px }
+pre { color: #036 }
+
+dl dt {
+ font-style: italic;
+ margin-top: .5em;
+ font-weight: bold;
+ color: #555;
+}
+hr {
+ color: #373;
+ background-color: #373;
+ height: 1px;
+ border: 0;
+ width: 100%;
+ margin: 2em 0;
+}
+
+/* Pudge Elements
+--------------------------------- */
+
+h1.pudge-member-page-heading {
+ font-size: 300%;
+ margin-top: .4em;
+ margin-bottom: .4em;
+}
+h4.pudge-member-page-subheading {
+ font-size: 150%;
+ font-style: italic;
+ margin-top: -1.3em;
+ margin-left: 2em;
+ color: #999;
+}
+p.pudge-member-blurb {
+ font-style: italic;
+ font-weight: bold;
+ font-size: 120%;
+ margin-top: 0.2em;
+ color: #6a6;
+}
+div.pudge-module-doc {
+ max-width: 45em;
+}
+div.pudge-section {
+ margin-left: 2em;
+ max-width: 45em;
+}
+p.pudge-member-blurb {
+ font-style: italic;
+ font-weight: bold;
+ font-size: 120%;
+}
+
+/* Section Navigation
+----------------------------------- */
+
+div#pudge-section-nav
+{
+ margin: 1em 0 1.5em 0;
+ padding: 0;
+ height: 20px;
+}
+
+div#pudge-section-nav ul {
+ border: 0;
+ margin: 0;
+ padding: 0;
+ list-style-type: none;
+ text-align: center;
+ border-right: 1px solid #aaa;
+}
+div#pudge-section-nav ul li
+{
+ display: block;
+ float: left;
+ text-align: center;
+ padding: 0;
+ margin: 0;
+}
+
+div#pudge-section-nav ul li .pudge-section-link,
+div#pudge-section-nav ul li .pudge-missing-section-link
+{
+ background: #aaa;
+ width: 11em;
+ height: 1.8em;
+ border: 0;
+ border-right: 3px solid #fff;
+ padding: 0;
+ margin: 0 0 10px 0;
+ color: #ddd;
+ text-decoration: none;
+ display: block;
+ text-align: center;
+ font: normal 10px/18px "Lucida Grande", "Lucida Sans Unicode", verdana, lucida, sans-serif;
+ font-weight: bold;
+ cursor: hand;
+}
+
+div#pudge-section-nav ul li a:hover
+{
+ color: #fff;
+ background: #393;
+}
+
+div#pudge-section-nav ul li .pudge-section-link
+{
+ background: #373;
+ color: #9c9;
+}
+
+/* Module Lists
+----------------------------------- */
+dl.pudge-module-list dt {
+ font-style: normal;
+ font-size: 110%;
+}
+dl.pudge-module-list dd {
+ color: #555;
+}
+
+/* misc */
+pre, tt {
+ font-size: 120%;
+}
--- /dev/null
+<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">
+<HTML>
+
+ <HEAD><META CONTENT="text/html; charset=utf-8" HTTP-EQUIV="Content-Type">
+ <TITLE>simplejson 1.7.1 -- Module Reference</TITLE>
+ <LINK HREF="layout.css" TYPE="text/css" REL="stylesheet">
+ </HEAD>
+ <BODY>
+ <DIV ID="page">
+
+ <DIV ID="top-nav">
+ <H1 ID="doc-title"><A HREF="index.html" REL="index">simplejson 1.7.1</A></H1>
+ <DIV CLASS="online-navigation">
+ <A HREF="index.html" REL="index">index</A>
+ <SPAN ID="nav-docs">
+
+ </SPAN>
+
+
+
+ <BR>
+
+ <A HREF="module-simplejson.html" TITLE="simplejson reference">
+ simplejson
+ </A>
+
+
+ </DIV>
+ </DIV>
+
+ <DIV ID="main-content">
+
+ <H1 CLASS="pudge-member-page-heading">
+ simplejson 1.7.1
+ </H1>
+ <H4 CLASS="pudge-member-page-subheading">
+ Module Reference
+ </H4>
+
+ <H2>Packages and Modules</H2>
+
+ <DL CLASS="pudge-module-list">
+
+ <DT><TT><A HREF="module-simplejson.html" CLASS="pudge-obj-link">
+ simplejson
+ </A></TT>
+ </DT>
+ <DD>
+ A simple, fast, extensible JSON encoder and decoder
+ </DD>
+
+ <DT><TT><A HREF="module-simplejson.encoder.html" CLASS="pudge-obj-link">
+ simplejson.encoder
+ </A></TT>
+ </DT>
+ <DD>
+ Implementation of JSONEncoder
+ </DD>
+
+ <DT><TT><A HREF="module-simplejson.jsonfilter.html" CLASS="pudge-obj-link">
+ simplejson.jsonfilter
+ </A></TT>
+ </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>
+ </DT>
+ <DD>
+ Implementation of JSONDecoder
+ </DD>
+
+ <DT><TT><A HREF="module-simplejson.scanner.html" CLASS="pudge-obj-link">
+ simplejson.scanner
+ </A></TT>
+ </DT>
+ <DD>
+ Iterator based sre token scanner
+ </DD>
+
+ <DT><TT><A HREF="module-simplejson._speedups.html" CLASS="pudge-obj-link">
+ simplejson._speedups
+ </A></TT>
+ </DT>
+
+
+ </DL>
+
+</DIV>
+
+ <DIV ID="footer">
+
+ <P ID="pudge">
+ Built with
+ <A HREF="http://lesscode.org/projects/pudge/">
+ Pudge/0.1.3</A>
+ </P>
+
+
+ </DIV>
+ </DIV>
+ </BODY>
+
+</HTML>
\ No newline at end of file
--- /dev/null
+<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">
+<HTML>
+
+ <HEAD><META CONTENT="text/html; charset=utf-8" HTTP-EQUIV="Content-Type">
+ <TITLE>Index of simplejson module</TITLE>
+ <LINK HREF="layout.css" TYPE="text/css" REL="stylesheet">
+ </HEAD>
+ <BODY>
+ <DIV ID="page">
+
+ <DIV ID="top-nav">
+ <H1 ID="doc-title"><A HREF="index.html" REL="index">simplejson 1.7.1</A></H1>
+ <DIV CLASS="online-navigation">
+ <A HREF="index.html" REL="index">index</A>
+ <SPAN ID="nav-docs">
+
+ </SPAN>
+
+
+
+ <BR>
+
+ <A HREF="module-simplejson.html" TITLE="simplejson reference">
+ simplejson
+ </A>
+
+
+
+ <A HREF="module-simplejson.html">details</A>
+
+ <A HREF="module-simplejson-index.html">
+ tree
+ </A>
+
+
+ </DIV>
+ </DIV>
+
+ <DIV ID="main-content">
+
+ <H1>Index of the <TT>simplejson</TT> module</H1>
+
+ <UL CLASS="pudge-module-index">
+ <LI CLASS="module">
+ <SPAN CLASS="prefix">m</SPAN>
+ <A HREF="module-simplejson.html">
+ <TT>simplejson</TT>
+ </A>
+ <A HREF="simplejson/__init__.py.html">...</A>
+ <SMALL>
+ - <SPAN CLASS="rst">A simple, fast, extensible JSON encoder and decoder</SPAN>
+ </SMALL>
+ <UL>
+
+
+
+
+
+ <LI CLASS="routine">
+ <SPAN CLASS="prefix">f</SPAN>
+ <A HREF="module-simplejson.html#load">
+ <TT>load</TT>
+ </A>
+ <A HREF="simplejson/__init__.py.html?f=220&l=242#220">...</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>
+ </SMALL>
+
+ </LI><LI CLASS="routine">
+ <SPAN CLASS="prefix">f</SPAN>
+ <A HREF="module-simplejson.html#dump">
+ <TT>dump</TT>
+ </A>
+ <A HREF="simplejson/__init__.py.html?f=108&l=164#108">...</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>
+ </SMALL>
+
+ </LI><LI CLASS="routine">
+ <SPAN CLASS="prefix">f</SPAN>
+ <A HREF="module-simplejson.html#dumps">
+ <TT>dumps</TT>
+ </A>
+ <A HREF="simplejson/__init__.py.html?f=166&l=217#166">...</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>
+
+ </LI><LI CLASS="routine">
+ <SPAN CLASS="prefix">f</SPAN>
+ <A HREF="module-simplejson.html#loads">
+ <TT>loads</TT>
+ </A>
+ <A HREF="simplejson/__init__.py.html?f=243&l=268#243">...</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>
+ </SMALL>
+
+ </LI>
+
+
+
+ </UL>
+ </LI>
+ </UL>
+
+
+
+</DIV>
+
+ <DIV ID="footer">
+
+ <P ID="pudge">
+ Built with
+ <A HREF="http://lesscode.org/projects/pudge/">
+ Pudge/0.1.3</A>
+ </P>
+
+
+ </DIV>
+ </DIV>
+ </BODY>
+
+</HTML>
\ No newline at end of file
--- /dev/null
+<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">
+<HTML>
+
+ <HEAD><META CONTENT="text/html; charset=utf-8" HTTP-EQUIV="Content-Type">
+ <TITLE>simplejson -- A simple, fast, extensible JSON encoder and decoder</TITLE>
+ <LINK HREF="layout.css" TYPE="text/css" REL="stylesheet">
+ </HEAD>
+ <BODY>
+ <DIV ID="page">
+
+ <DIV ID="top-nav">
+ <H1 ID="doc-title"><A HREF="index.html" REL="index">simplejson 1.7.1</A></H1>
+ <DIV CLASS="online-navigation">
+ <A HREF="index.html" REL="index">index</A>
+ <SPAN ID="nav-docs">
+
+ </SPAN>
+
+
+
+ <BR>
+
+ <A HREF="module-simplejson.html" TITLE="simplejson reference">
+ simplejson
+ </A>
+
+
+
+ <A HREF="module-simplejson.html">details</A>
+
+ <A HREF="module-simplejson-index.html">
+ tree
+ </A>
+
+
+ </DIV>
+ </DIV>
+
+ <DIV ID="main-content">
+
+ <H1 CLASS="pudge-member-page-heading">
+ <TT>simplejson</TT>
+ </H1>
+ <H4 CLASS="pudge-member-page-subheading">
+ A simple, fast, extensible JSON encoder and decoder
+ </H4>
+
+ <DIV ID="pudge-section-nav">
+ <UL>
+ <LI>
+
+ <SPAN CLASS="pudge-missing-section-link">
+ Attributes
+ </SPAN>
+ </LI><LI>
+ <A HREF="#functions" CLASS="pudge-section-link">
+ Functions (4)
+ </A>
+
+ </LI><LI>
+ <A HREF="#classes" CLASS="pudge-section-link">
+ Classes (2)
+ </A>
+
+ </LI><LI>
+
+ <SPAN CLASS="pudge-missing-section-link">
+ Modules
+ </SPAN>
+ </LI>
+ <LI>
+ <A HREF="module-simplejson-index.html" CLASS="pudge-section-link">
+ Index
+ </A>
+ </LI>
+ <LI>
+ <A HREF="simplejson/__init__.py.html" CLASS="pudge-section-link">
+ Source
+ </A>
+ </LI>
+ </UL>
+ </DIV>
+ <DIV STYLE="clear: left"></DIV>
+ <DIV CLASS="rst pudge-module-doc">
+ <P>JSON (JavaScript Object Notation) <<A HREF="http://json.org" CLASS="reference">http://json.org</A>> is a subset of
+JavaScript syntax (ECMA-262 3rd edition) used as a lightweight data
+interchange format.</P>
+<P>simplejson exposes an API familiar to uses of the standard library
+marshal and pickle modules.</P>
+<P>Encoding basic Python object hierarchies:</P>
+<PRE CLASS="literal-block">
+>>> import simplejson
+>>> simplejson.dumps(['foo', {'bar': ('baz', None, 1.0, 2)}])
+'["foo", {"bar": ["baz", null, 1.0, 2]}]'
+>>> print simplejson.dumps("\"foo\bar")
+"\"foo\bar"
+>>> print simplejson.dumps(u'\u1234')
+"\u1234"
+>>> print simplejson.dumps('\\')
+"\\"
+>>> print simplejson.dumps({"c": 0, "b": 0, "a": 0}, sort_keys=True)
+{"a": 0, "b": 0, "c": 0}
+>>> from StringIO import StringIO
+>>> io = StringIO()
+>>> simplejson.dump(['streaming API'], io)
+>>> io.getvalue()
+'["streaming API"]'
+</PRE>
+<P>Compact encoding:</P>
+<PRE CLASS="literal-block">
+>>> import simplejson
+>>> simplejson.dumps([1,2,3,{'4': 5, '6': 7}], separators=(',',':'))
+'[1,2,3,{"4":5,"6":7}]'
+</PRE>
+<P>Pretty printing:</P>
+<PRE CLASS="literal-block">
+>>> import simplejson
+>>> print simplejson.dumps({'4': 5, '6': 7}, sort_keys=True, indent=4)
+{
+ "4": 5,
+ "6": 7
+}
+</PRE>
+<P>Decoding JSON:</P>
+<PRE CLASS="literal-block">
+>>> import simplejson
+>>> simplejson.loads('["foo", {"bar":["baz", null, 1.0, 2]}]')
+[u'foo', {u'bar': [u'baz', None, 1.0, 2]}]
+>>> simplejson.loads('"\\"foo\\bar"')
+u'"foo\x08ar'
+>>> from StringIO import StringIO
+>>> io = StringIO('["streaming API"]')
+>>> simplejson.load(io)
+[u'streaming API']
+</PRE>
+<P>Specializing JSON object decoding:</P>
+<PRE CLASS="literal-block">
+>>> import simplejson
+>>> def as_complex(dct):
+... if '__complex__' in dct:
+... return complex(dct['real'], dct['imag'])
+... return dct
+...
+>>> simplejson.loads('{"__complex__": true, "real": 1, "imag": 2}',
+... object_hook=as_complex)
+(1+2j)
+</PRE>
+<P>Extending JSONEncoder:</P>
+<PRE CLASS="literal-block">
+>>> import simplejson
+>>> class ComplexEncoder(simplejson.JSONEncoder):
+... def default(self, obj):
+... if isinstance(obj, complex):
+... return [obj.real, obj.imag]
+... return simplejson.JSONEncoder.default(self, obj)
+...
+>>> dumps(2 + 1j, cls=ComplexEncoder)
+'[2.0, 1.0]'
+>>> ComplexEncoder().encode(2 + 1j)
+'[2.0, 1.0]'
+>>> list(ComplexEncoder().iterencode(2 + 1j))
+['[', '2.0', ', ', '1.0', ']']
+</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>
+
+ </DIV>
+
+ <HR>
+
+
+ <A NAME="functions"></A>
+ <H2>Functions</H2>
+ <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=108&l=164#108" TITLE="View Source">...</A>
+ </H4>
+ <DIV CLASS="pudge-section rst">
+
+ <P CLASS="pudge-member-blurb">
+ 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).
+ </P>
+ <P>If <TT CLASS="docutils literal"><SPAN CLASS="pre">skipkeys</SPAN></TT> is <TT CLASS="docutils literal"><SPAN CLASS="pre">True</SPAN></TT> then <TT CLASS="docutils literal"><SPAN CLASS="pre">dict</SPAN></TT> keys that are not basic types
+(<TT CLASS="docutils literal"><SPAN CLASS="pre">str</SPAN></TT>, <TT CLASS="docutils literal"><SPAN CLASS="pre">unicode</SPAN></TT>, <TT CLASS="docutils literal"><SPAN CLASS="pre">int</SPAN></TT>, <TT CLASS="docutils literal"><SPAN CLASS="pre">long</SPAN></TT>, <TT CLASS="docutils literal"><SPAN CLASS="pre">float</SPAN></TT>, <TT CLASS="docutils literal"><SPAN CLASS="pre">bool</SPAN></TT>, <TT CLASS="docutils literal"><SPAN CLASS="pre">None</SPAN></TT>)
+will be skipped instead of raising a <TT CLASS="docutils literal"><SPAN CLASS="pre">TypeError</SPAN></TT>.</P>
+<P>If <TT CLASS="docutils literal"><SPAN CLASS="pre">ensure_ascii</SPAN></TT> is <TT CLASS="docutils literal"><SPAN CLASS="pre">False</SPAN></TT>, then the some chunks written to <TT CLASS="docutils literal"><SPAN CLASS="pre">fp</SPAN></TT>
+may be <TT CLASS="docutils literal"><SPAN CLASS="pre">unicode</SPAN></TT> instances, subject to normal Python <TT CLASS="docutils literal"><SPAN CLASS="pre">str</SPAN></TT> to
+<TT CLASS="docutils literal"><SPAN CLASS="pre">unicode</SPAN></TT> coercion rules. Unless <TT CLASS="docutils literal"><SPAN CLASS="pre">fp.write()</SPAN></TT> explicitly
+understands <TT CLASS="docutils literal"><SPAN CLASS="pre">unicode</SPAN></TT> (as in <TT CLASS="docutils literal"><SPAN CLASS="pre">codecs.getwriter()</SPAN></TT>) this is likely
+to cause an error.</P>
+<P>If <TT CLASS="docutils literal"><SPAN CLASS="pre">check_circular</SPAN></TT> is <TT CLASS="docutils literal"><SPAN CLASS="pre">False</SPAN></TT>, then the circular reference check
+for container types will be skipped and a circular reference will
+result in an <TT CLASS="docutils literal"><SPAN CLASS="pre">OverflowError</SPAN></TT> (or worse).</P>
+<P>If <TT CLASS="docutils literal"><SPAN CLASS="pre">allow_nan</SPAN></TT> is <TT CLASS="docutils literal"><SPAN CLASS="pre">False</SPAN></TT>, then it will be a <TT CLASS="docutils literal"><SPAN CLASS="pre">ValueError</SPAN></TT> to
+serialize out of range <TT CLASS="docutils literal"><SPAN CLASS="pre">float</SPAN></TT> values (<TT CLASS="docutils literal"><SPAN CLASS="pre">nan</SPAN></TT>, <TT CLASS="docutils literal"><SPAN CLASS="pre">inf</SPAN></TT>, <TT CLASS="docutils literal"><SPAN CLASS="pre">-inf</SPAN></TT>)
+in strict compliance of the JSON specification, instead of using the
+JavaScript equivalents (<TT CLASS="docutils literal"><SPAN CLASS="pre">NaN</SPAN></TT>, <TT CLASS="docutils literal"><SPAN CLASS="pre">Infinity</SPAN></TT>, <TT CLASS="docutils literal"><SPAN CLASS="pre">-Infinity</SPAN></TT>).</P>
+<P>If <TT CLASS="docutils literal"><SPAN CLASS="pre">indent</SPAN></TT> is a non-negative integer, then JSON array elements and object
+members will be pretty-printed with that indent level. An indent level
+of 0 will only insert newlines. <TT CLASS="docutils literal"><SPAN CLASS="pre">None</SPAN></TT> is the most compact representation.</P>
+<P>If <TT CLASS="docutils literal"><SPAN CLASS="pre">separators</SPAN></TT> is an <TT CLASS="docutils literal"><SPAN CLASS="pre">(item_separator,</SPAN> <SPAN CLASS="pre">dict_separator)</SPAN></TT> tuple
+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>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>
+
+
+ </DIV>
+ </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=166&l=217#166" TITLE="View Source">...</A>
+ </H4>
+ <DIV CLASS="pudge-section rst">
+
+ <P CLASS="pudge-member-blurb">
+ 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>.
+ </P>
+ <P>If <TT CLASS="docutils literal"><SPAN CLASS="pre">skipkeys</SPAN></TT> is <TT CLASS="docutils literal"><SPAN CLASS="pre">True</SPAN></TT> then <TT CLASS="docutils literal"><SPAN CLASS="pre">dict</SPAN></TT> keys that are not basic types
+(<TT CLASS="docutils literal"><SPAN CLASS="pre">str</SPAN></TT>, <TT CLASS="docutils literal"><SPAN CLASS="pre">unicode</SPAN></TT>, <TT CLASS="docutils literal"><SPAN CLASS="pre">int</SPAN></TT>, <TT CLASS="docutils literal"><SPAN CLASS="pre">long</SPAN></TT>, <TT CLASS="docutils literal"><SPAN CLASS="pre">float</SPAN></TT>, <TT CLASS="docutils literal"><SPAN CLASS="pre">bool</SPAN></TT>, <TT CLASS="docutils literal"><SPAN CLASS="pre">None</SPAN></TT>)
+will be skipped instead of raising a <TT CLASS="docutils literal"><SPAN CLASS="pre">TypeError</SPAN></TT>.</P>
+<P>If <TT CLASS="docutils literal"><SPAN CLASS="pre">ensure_ascii</SPAN></TT> is <TT CLASS="docutils literal"><SPAN CLASS="pre">False</SPAN></TT>, then the return value will be a
+<TT CLASS="docutils literal"><SPAN CLASS="pre">unicode</SPAN></TT> instance subject to normal Python <TT CLASS="docutils literal"><SPAN CLASS="pre">str</SPAN></TT> to <TT CLASS="docutils literal"><SPAN CLASS="pre">unicode</SPAN></TT>
+coercion rules instead of being escaped to an ASCII <TT CLASS="docutils literal"><SPAN CLASS="pre">str</SPAN></TT>.</P>
+<P>If <TT CLASS="docutils literal"><SPAN CLASS="pre">check_circular</SPAN></TT> is <TT CLASS="docutils literal"><SPAN CLASS="pre">False</SPAN></TT>, then the circular reference check
+for container types will be skipped and a circular reference will
+result in an <TT CLASS="docutils literal"><SPAN CLASS="pre">OverflowError</SPAN></TT> (or worse).</P>
+<P>If <TT CLASS="docutils literal"><SPAN CLASS="pre">allow_nan</SPAN></TT> is <TT CLASS="docutils literal"><SPAN CLASS="pre">False</SPAN></TT>, then it will be a <TT CLASS="docutils literal"><SPAN CLASS="pre">ValueError</SPAN></TT> to
+serialize out of range <TT CLASS="docutils literal"><SPAN CLASS="pre">float</SPAN></TT> values (<TT CLASS="docutils literal"><SPAN CLASS="pre">nan</SPAN></TT>, <TT CLASS="docutils literal"><SPAN CLASS="pre">inf</SPAN></TT>, <TT CLASS="docutils literal"><SPAN CLASS="pre">-inf</SPAN></TT>) in
+strict compliance of the JSON specification, instead of using the
+JavaScript equivalents (<TT CLASS="docutils literal"><SPAN CLASS="pre">NaN</SPAN></TT>, <TT CLASS="docutils literal"><SPAN CLASS="pre">Infinity</SPAN></TT>, <TT CLASS="docutils literal"><SPAN CLASS="pre">-Infinity</SPAN></TT>).</P>
+<P>If <TT CLASS="docutils literal"><SPAN CLASS="pre">indent</SPAN></TT> is a non-negative integer, then JSON array elements and
+object members will be pretty-printed with that indent level. An indent
+level of 0 will only insert newlines. <TT CLASS="docutils literal"><SPAN CLASS="pre">None</SPAN></TT> is the most compact
+representation.</P>
+<P>If <TT CLASS="docutils literal"><SPAN CLASS="pre">separators</SPAN></TT> is an <TT CLASS="docutils literal"><SPAN CLASS="pre">(item_separator,</SPAN> <SPAN CLASS="pre">dict_separator)</SPAN></TT> tuple
+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>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>
+
+
+ </DIV>
+ </DIV><DIV CLASS="pudge-member routine ">
+ <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, **kw)</TT>
+ <A HREF="simplejson/__init__.py.html?f=220&l=242#220" TITLE="View Source">...</A>
+ </H4>
+ <DIV CLASS="pudge-section rst">
+
+ <P CLASS="pudge-member-blurb">
+ 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.
+ </P>
+ <P>If the contents of <TT CLASS="docutils literal"><SPAN CLASS="pre">fp</SPAN></TT> is encoded with an ASCII based encoding other
+than utf-8 (e.g. latin-1), then an appropriate <TT CLASS="docutils literal"><SPAN CLASS="pre">encoding</SPAN></TT> name must
+be specified. Encodings that are not ASCII based (such as UCS-2) are
+not allowed, and should be wrapped with
+<TT CLASS="docutils literal"><SPAN CLASS="pre">codecs.getreader(fp)(encoding)</SPAN></TT>, or simply decoded to a <TT CLASS="docutils literal"><SPAN CLASS="pre">unicode</SPAN></TT>
+object and passed to <TT CLASS="docutils literal"><SPAN CLASS="pre">loads()</SPAN></TT></P>
+<P><TT CLASS="docutils literal"><SPAN CLASS="pre">object_hook</SPAN></TT> is an optional function that will be called with the
+result of any object literal decode (a <TT CLASS="docutils literal"><SPAN CLASS="pre">dict</SPAN></TT>). The return value of
+<TT CLASS="docutils literal"><SPAN CLASS="pre">object_hook</SPAN></TT> will be used instead of the <TT CLASS="docutils literal"><SPAN CLASS="pre">dict</SPAN></TT>. This feature
+can be used to implement custom decoders (e.g. JSON-RPC class hinting).</P>
+<P>To use a custom <TT CLASS="docutils literal"><SPAN CLASS="pre">JSONDecoder</SPAN></TT> subclass, specify it with the <TT CLASS="docutils literal"><SPAN CLASS="pre">cls</SPAN></TT>
+kwarg.</P>
+
+
+ </DIV>
+ </DIV><DIV CLASS="pudge-member routine ">
+ <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, **kw)</TT>
+ <A HREF="simplejson/__init__.py.html?f=243&l=268#243" TITLE="View Source">...</A>
+ </H4>
+ <DIV CLASS="pudge-section rst">
+
+ <P CLASS="pudge-member-blurb">
+ 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.
+ </P>
+ <P>If <TT CLASS="docutils literal"><SPAN CLASS="pre">s</SPAN></TT> is a <TT CLASS="docutils literal"><SPAN CLASS="pre">str</SPAN></TT> instance and is encoded with an ASCII based encoding
+other than utf-8 (e.g. latin-1) then an appropriate <TT CLASS="docutils literal"><SPAN CLASS="pre">encoding</SPAN></TT> name
+must be specified. Encodings that are not ASCII based (such as UCS-2)
+are not allowed and should be decoded to <TT CLASS="docutils literal"><SPAN CLASS="pre">unicode</SPAN></TT> first.</P>
+<P><TT CLASS="docutils literal"><SPAN CLASS="pre">object_hook</SPAN></TT> is an optional function that will be called with the
+result of any object literal decode (a <TT CLASS="docutils literal"><SPAN CLASS="pre">dict</SPAN></TT>). The return value of
+<TT CLASS="docutils literal"><SPAN CLASS="pre">object_hook</SPAN></TT> will be used instead of the <TT CLASS="docutils literal"><SPAN CLASS="pre">dict</SPAN></TT>. This feature
+can be used to implement custom decoders (e.g. JSON-RPC class hinting).</P>
+<P>To use a custom <TT CLASS="docutils literal"><SPAN CLASS="pre">JSONDecoder</SPAN></TT> subclass, specify it with the <TT CLASS="docutils literal"><SPAN CLASS="pre">cls</SPAN></TT>
+kwarg.</P>
+
+
+ </DIV>
+ </DIV>
+
+
+ <A NAME="classes"></A>
+ <H2>Classes</H2>
+ <DIV CLASS="pudge-member class alias">
+ <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=80&l=370#80" CLASS="pudge-member-view-source" TITLE="View Source">...</A>
+ </H4>
+ <DIV CLASS="pudge-section rst">
+
+ <P CLASS="pudge-member-blurb">
+ Extensible JSON <<A HREF="http://json.org" CLASS="reference">http://json.org</A>> encoder for Python data structures.
+ </P>
+ <P>Supports the following objects and types by default:</P>
+<TABLE BORDER="1" CLASS="docutils">
+<COLGROUP>
+<COL WIDTH="56%">
+<COL WIDTH="44%">
+</COLGROUP>
+<THEAD VALIGN="bottom">
+<TR><TH CLASS="head">Python</TH>
+<TH CLASS="head">JSON</TH>
+</TR>
+</THEAD>
+<TBODY VALIGN="top">
+<TR><TD>dict</TD>
+<TD>object</TD>
+</TR>
+<TR><TD>list, tuple</TD>
+<TD>array</TD>
+</TR>
+<TR><TD>str, unicode</TD>
+<TD>string</TD>
+</TR>
+<TR><TD>int, long, float</TD>
+<TD>number</TD>
+</TR>
+<TR><TD>True</TD>
+<TD>true</TD>
+</TR>
+<TR><TD>False</TD>
+<TD>false</TD>
+</TR>
+<TR><TD>None</TD>
+<TD>null</TD>
+</TR>
+</TBODY>
+</TABLE>
+<P>To extend this to recognize other objects, subclass and implement a
+<TT CLASS="docutils literal"><SPAN CLASS="pre">.default()</SPAN></TT> method with another method that returns a serializable
+object for <TT CLASS="docutils literal"><SPAN CLASS="pre">o</SPAN></TT> if possible, otherwise it should call the superclass
+implementation (to raise <TT CLASS="docutils literal"><SPAN CLASS="pre">TypeError</SPAN></TT>).</P>
+
+
+
+ <P CLASS="note">
+ This class contains <A HREF="class-simplejson.JSONEncoder.html#members">
+ 5 members</A>.
+ </P>
+ </DIV>
+ </DIV><DIV CLASS="pudge-member class alias">
+ <H4 CLASS="pudge-member-name"><SPAN CLASS="prefix">C</SPAN>
+ <TT>
+ <A HREF="class-simplejson.JSONDecoder.html" CLASS="pudge-obj-link">JSONDecoder</A>(...)</TT>
+ <A HREF="simplejson/decoder.py.html?f=196&l=272#196" CLASS="pudge-member-view-source" TITLE="View Source">...</A>
+ </H4>
+ <DIV CLASS="pudge-section rst">
+
+ <P CLASS="pudge-member-blurb">
+ Simple JSON <<A HREF="http://json.org" CLASS="reference">http://json.org</A>> decoder
+ </P>
+ <P>Performs the following translations in decoding:</P>
+<TABLE BORDER="1" CLASS="docutils">
+<COLGROUP>
+<COL WIDTH="44%">
+<COL WIDTH="56%">
+</COLGROUP>
+<THEAD VALIGN="bottom">
+<TR><TH CLASS="head">JSON</TH>
+<TH CLASS="head">Python</TH>
+</TR>
+</THEAD>
+<TBODY VALIGN="top">
+<TR><TD>object</TD>
+<TD>dict</TD>
+</TR>
+<TR><TD>array</TD>
+<TD>list</TD>
+</TR>
+<TR><TD>string</TD>
+<TD>unicode</TD>
+</TR>
+<TR><TD>number (int)</TD>
+<TD>int, long</TD>
+</TR>
+<TR><TD>number (real)</TD>
+<TD>float</TD>
+</TR>
+<TR><TD>true</TD>
+<TD>True</TD>
+</TR>
+<TR><TD>false</TD>
+<TD>False</TD>
+</TR>
+<TR><TD>null</TD>
+<TD>None</TD>
+</TR>
+</TBODY>
+</TABLE>
+<P>It also understands <TT CLASS="docutils literal"><SPAN CLASS="pre">NaN</SPAN></TT>, <TT CLASS="docutils literal"><SPAN CLASS="pre">Infinity</SPAN></TT>, and <TT CLASS="docutils literal"><SPAN CLASS="pre">-Infinity</SPAN></TT> as
+their corresponding <TT CLASS="docutils literal"><SPAN CLASS="pre">float</SPAN></TT> values, which is outside the JSON spec.</P>
+
+
+
+ <P CLASS="note">
+ This class contains <A HREF="class-simplejson.JSONDecoder.html#members">
+ 4 members</A>.
+ </P>
+ </DIV>
+ </DIV>
+
+
+
+ <P>
+ <SMALL>
+
+
+ See
+ <A HREF="simplejson/__init__.py.html" TITLE="simplejson/__init__.py:0">the source</A>
+ for more information.
+ </SMALL>
+ </P>
+
+</DIV>
+
+ <DIV ID="footer">
+
+ <P ID="pudge">
+ Built with
+ <A HREF="http://lesscode.org/projects/pudge/">
+ Pudge/0.1.3</A>
+ </P>
+
+
+ </DIV>
+ </DIV>
+ </BODY>
+
+</HTML>
\ No newline at end of file
--- /dev/null
+/* Layout
+----------------------------------- */
+
+@import url("rst.css");
+
+/* Pudge Elements
+----------------------------------- */
+.note { font-size: 90% }
+h4.pudge-member-name {
+ font-size: 110%;
+ margin-bottom: 0;
+}
+h4.pudge-member-name a.obj-link {
+ font-weight: bold;
+ text-decoration: none;
+}
+h4.pudge-member-name .prefix {
+ font-style: oblique;
+ padding-right: 6px;
+ font-weight: bold;
+ color: #c9c;
+}
+h1.pudge-member-page-heading {
+ font-size: 250%;
+}
+h4.pudge-member-page-subheading {
+ font-size: 150%;
+ font-style: italic;
+}
+h4.pudge-member-page-subheading p {
+ display: inline;
+}
+div.pudge-member {
+ margin-top: 1.5em;
+ margin-bottom: 1.5em;
+}
+ul.pudge-module-index {
+ margin-left: 0;
+ padding-left: 0;
+}
+ul.pudge-module-index ul {
+ padding-left: 1.5em;
+ margin-left: 0;
+}
+ul.pudge-module-index li {
+ list-style-type: none;
+}
+ul.pudge-module-index .prefix {
+ font-style: oblique;
+ padding-right: 6px;
+ font-size: 90%;
+ font-weight: bold;
+ color: purple;
+}
+ul.pudge-module-index a {
+ text-decoration: none;
+}
+div.pudge-section {
+ margin-left: 2em;
+}
\ No newline at end of file
--- /dev/null
+/* Headings
+ ------------------------------- */
+
+.rst h1 { font-size: 110% }
+.rst h2 { font-size: 100% }
+
+/*.rst-doc h1 { font-size: 200% }
+.rst-doc h2 { font-size: 140% }
+.rst-doc h3 { font-size: 110% }*/
+.rst-doc h1.title { font-size: 220% }
+.rst-doc h1 a, .rst-doc h2 a, .rst-doc h3 a {
+ color: inherit ;
+ font-weight: inherit;
+ text-decoration: inherit;
+}
+
+/* Blockquotes
+ ------------------------------- */
+
+.rst blockquote,
+.rst-doc blockquote {
+ font-style: italic;
+ font-family: Georgia, serif;
+ max-width: 30em;
+}
+
+/* Document Info
+ ------------------------------- */
+.rst-doc table.docinfo {
+ margin: 2em 0
+ width: 100%;
+}
+.rst-doc table.docinfo th {
+ text-align: left ;
+ padding-right: 2em;
+ color: #555;
+}
+.rst-doc table.docinfo td {
+ text-align: left
+}
+
+/* Field Lists
+ ------------------------------- */
+
+.rst table.field-list,
+.rst-doc table.field-list {
+ border: 0;
+ margin-left: 0;
+}
+.rst table.field-list ul,
+.rst-doc table.field-list ul {
+ margin-left: 0;
+}
+.rst-doc table.field-list ul {
+ border: 0;
+ margin-left: 2em;
+ background: #fff;
+ color: #119;
+}
+
+/* Tables
+ ------------------------------- */
+
+.rst table.docutils,
+.rst-doc table.docutils {
+ border: 0;
+}
+.rst table.docutils th,
+.rst-doc table.docutils th {
+ border: 0;
+ background: #777;
+ color: #fff;
+ padding: 3px;
+}
+.rst table.docutils td,
+.rst-doc table.docutils td {
+ border: 0;
+ border-bottom: 1px solid #ccc;
+ padding-bottom: 2px;
+}
+
+/* Contents and Back References
+ ------------------------------- */
+
+.rst-doc div.contents {
+ margin: 2em inherit;
+}
+.rst-doc div.contents ul {
+ margin-left: 0;
+ padding-left: 2em;
+ line-height: 150%;
+}
+.rst-doc div.contents ul li {
+ font-weight: bold;
+ list-style-type: none;
+}
+.rst-doc div.contents p.topic-title {
+ font-size: 160%;
+ font-weight: normal;
+ color: #555;
+ margin-top: .5em;
+}
+.rst-doc .contents .reference,
+.rst-doc .toc-backref {
+ text-decoration: none;
+}
+
+/* Admonitions
+ ------------------------------- */
+
+.rst-doc div.admonition,
+.rst-doc div.warning,
+.rst-doc div.note {
+ margin: 2.5em 6em;
+ padding: .6em 2.5em;
+ background: #ddf;
+ border: 2px solid #ccc;
+ font-family: Georgia, serif;
+ color: #333;
+}
+.rst-doc div.warning {
+ background: #ff8;
+ border-color: #fe2;
+}
+.rst-doc div .admonition-title {
+ font-weight: bold;
+ font-style: italic;
+ color: #223;
+ font-size: 110%;
+ font-family: sans-serif;
+}
+
+/* Misc
+ ------------------------------- */
+
+tt.literal {
+ color: #333;
+}
+.footnote-reference {
+ vertical-align: super;
+ font-size: 20%;
+}
\ No newline at end of file
--- /dev/null
+<html><head><title>/Users/bob/src/simplejson/simplejson/__init__.py</title>
+ <script type="text/javascript"><!--
+
+function show_line_range() {
+ var href = document.location.href;
+ if (href.indexOf('?') == -1) {
+ return;
+ }
+ var qs = href.substring(href.indexOf('?')+1);
+ if (qs.indexOf('#') >= 0) {
+ qs = qs.substring(0, qs.indexOf('#'));
+ }
+ var first = qs.match(/f=(\d+)/)[1];
+ var last = qs.match(/l=(\d+)/)[1];
+ if (! first || ! last) {
+ return;
+ }
+ var anchors = document.getElementsByTagName('A');
+ var container = document.createElement('DIV');
+ container.className = 'highlighted';
+ var children = [];
+ var start = null;
+ var parent = null;
+ var highlight = false;
+ for (var i = 0; i < anchors.length; i++) {
+ var el = anchors[i];
+ if (el.getAttribute('name') == first) {
+ start = el.previousSibling;
+ parent = el.parentNode;
+ highlight = true;
+ }
+ if (el.getAttribute('name') == last) {
+ break;
+ }
+ if (highlight) {
+ children[children.length] = el;
+ el = el.nextSibling;
+ while (el && el.tagName != 'A') {
+ children[children.length] = el;
+ el = el.nextSibling;
+ }
+ }
+ }
+ for (i=0; i<children.length; i++) {
+ container.appendChild(children[i]);
+ }
+ if (start) {
+ start.parentNode.insertBefore(container, start.nextSibling);
+ } else {
+ parent.insertBefore(container, parent.childNodes[0]);
+ }
+}
+
+ // --></script>
+ <style>
+ div.python {
+ color: #333
+ }
+ div.python a.lnum {
+ color: #555;
+ background-color: #eee;
+ border-right: 1px solid #999;
+ padding-right: 2px;
+ margin-right: 4px;
+ }
+ div.python span.comment { color: #933 }
+ div.python span.keyword { color: #a3e; font-weight: bold }
+ div.python span.op { color: #c96 }
+ div.python span.string { color: #6a6 }
+ div.python span.name { }
+ div.python span.text { color: #333 }
+ div.highlighted { background-color: #ff9; border: 1px solid #009 }
+ </style></head><body onload="show_line_range()"><div class="python"><code><a class="lnum" href="#1" name="1">0001</a><span class="string">r"""</span><br />
+<a class="lnum" href="#2" name="2">0002</a><span class="string">A simple, fast, extensible JSON encoder and decoder</span><br />
+<a class="lnum" href="#3" name="3">0003</a><span class="string"></span><br />
+<a class="lnum" href="#4" name="4">0004</a><span class="string">JSON (JavaScript Object Notation) <http://json.org> is a subset of</span><br />
+<a class="lnum" href="#5" name="5">0005</a><span class="string">JavaScript syntax (ECMA-262 3rd edition) used as a lightweight data</span><br />
+<a class="lnum" href="#6" name="6">0006</a><span class="string">interchange format.</span><br />
+<a class="lnum" href="#7" name="7">0007</a><span class="string"></span><br />
+<a class="lnum" href="#8" name="8">0008</a><span class="string">simplejson exposes an API familiar to uses of the standard library</span><br />
+<a class="lnum" href="#9" name="9">0009</a><span class="string">marshal and pickle modules.</span><br />
+<a class="lnum" href="#10" name="10">0010</a><span class="string"></span><br />
+<a class="lnum" href="#11" name="11">0011</a><span class="string">Encoding basic Python object hierarchies::</span><br />
+<a class="lnum" href="#12" name="12">0012</a><span class="string">    </span><br />
+<a class="lnum" href="#13" name="13">0013</a><span class="string">    >>> import simplejson</span><br />
+<a class="lnum" href="#14" name="14">0014</a><span class="string">    >>> simplejson.dumps(['foo', {'bar': ('baz', None, 1.0, 2)}])</span><br />
+<a class="lnum" href="#15" name="15">0015</a><span class="string">    '["foo", {"bar": ["baz", null, 1.0, 2]}]'</span><br />
+<a class="lnum" href="#16" name="16">0016</a><span class="string">    >>> print simplejson.dumps("\"foo\bar")</span><br />
+<a class="lnum" href="#17" name="17">0017</a><span class="string">    "\"foo\bar"</span><br />
+<a class="lnum" href="#18" name="18">0018</a><span class="string">    >>> print simplejson.dumps(u'\u1234')</span><br />
+<a class="lnum" href="#19" name="19">0019</a><span class="string">    "\u1234"</span><br />
+<a class="lnum" href="#20" name="20">0020</a><span class="string">    >>> print simplejson.dumps('\\')</span><br />
+<a class="lnum" href="#21" name="21">0021</a><span class="string">    "\\"</span><br />
+<a class="lnum" href="#22" name="22">0022</a><span class="string">    >>> print simplejson.dumps({"c": 0, "b": 0, "a": 0}, sort_keys=True)</span><br />
+<a class="lnum" href="#23" name="23">0023</a><span class="string">    {"a": 0, "b": 0, "c": 0}</span><br />
+<a class="lnum" href="#24" name="24">0024</a><span class="string">    >>> from StringIO import StringIO</span><br />
+<a class="lnum" href="#25" name="25">0025</a><span class="string">    >>> io = StringIO()</span><br />
+<a class="lnum" href="#26" name="26">0026</a><span class="string">    >>> simplejson.dump(['streaming API'], io)</span><br />
+<a class="lnum" href="#27" name="27">0027</a><span class="string">    >>> io.getvalue()</span><br />
+<a class="lnum" href="#28" name="28">0028</a><span class="string">    '["streaming API"]'</span><br />
+<a class="lnum" href="#29" name="29">0029</a><span class="string"></span><br />
+<a class="lnum" href="#30" name="30">0030</a><span class="string">Compact encoding::</span><br />
+<a class="lnum" href="#31" name="31">0031</a><span class="string"></span><br />
+<a class="lnum" href="#32" name="32">0032</a><span class="string">    >>> import simplejson</span><br />
+<a class="lnum" href="#33" name="33">0033</a><span class="string">    >>> simplejson.dumps([1,2,3,{'4': 5, '6': 7}], separators=(',',':'))</span><br />
+<a class="lnum" href="#34" name="34">0034</a><span class="string">    '[1,2,3,{"4":5,"6":7}]'</span><br />
+<a class="lnum" href="#35" name="35">0035</a><span class="string"></span><br />
+<a class="lnum" href="#36" name="36">0036</a><span class="string">Pretty printing::</span><br />
+<a class="lnum" href="#37" name="37">0037</a><span class="string"></span><br />
+<a class="lnum" href="#38" name="38">0038</a><span class="string">    >>> import simplejson</span><br />
+<a class="lnum" href="#39" name="39">0039</a><span class="string">    >>> print simplejson.dumps({'4': 5, '6': 7}, sort_keys=True, indent=4)</span><br />
+<a class="lnum" href="#40" name="40">0040</a><span class="string">    {</span><br />
+<a class="lnum" href="#41" name="41">0041</a><span class="string">        "4": 5, </span><br />
+<a class="lnum" href="#42" name="42">0042</a><span class="string">        "6": 7</span><br />
+<a class="lnum" href="#43" name="43">0043</a><span class="string">    }</span><br />
+<a class="lnum" href="#44" name="44">0044</a><span class="string"></span><br />
+<a class="lnum" href="#45" name="45">0045</a><span class="string">Decoding JSON::</span><br />
+<a class="lnum" href="#46" name="46">0046</a><span class="string">    </span><br />
+<a class="lnum" href="#47" name="47">0047</a><span class="string">    >>> import simplejson</span><br />
+<a class="lnum" href="#48" name="48">0048</a><span class="string">    >>> simplejson.loads('["foo", {"bar":["baz", null, 1.0, 2]}]')</span><br />
+<a class="lnum" href="#49" name="49">0049</a><span class="string">    [u'foo', {u'bar': [u'baz', None, 1.0, 2]}]</span><br />
+<a class="lnum" href="#50" name="50">0050</a><span class="string">    >>> simplejson.loads('"\\"foo\\bar"')</span><br />
+<a class="lnum" href="#51" name="51">0051</a><span class="string">    u'"foo\x08ar'</span><br />
+<a class="lnum" href="#52" name="52">0052</a><span class="string">    >>> from StringIO import StringIO</span><br />
+<a class="lnum" href="#53" name="53">0053</a><span class="string">    >>> io = StringIO('["streaming API"]')</span><br />
+<a class="lnum" href="#54" name="54">0054</a><span class="string">    >>> simplejson.load(io)</span><br />
+<a class="lnum" href="#55" name="55">0055</a><span class="string">    [u'streaming API']</span><br />
+<a class="lnum" href="#56" name="56">0056</a><span class="string"></span><br />
+<a class="lnum" href="#57" name="57">0057</a><span class="string">Specializing JSON object decoding::</span><br />
+<a class="lnum" href="#58" name="58">0058</a><span class="string"></span><br />
+<a class="lnum" href="#59" name="59">0059</a><span class="string">    >>> import simplejson</span><br />
+<a class="lnum" href="#60" name="60">0060</a><span class="string">    >>> def as_complex(dct):</span><br />
+<a class="lnum" href="#61" name="61">0061</a><span class="string">    ...     if '__complex__' in dct:</span><br />
+<a class="lnum" href="#62" name="62">0062</a><span class="string">    ...         return complex(dct['real'], dct['imag'])</span><br />
+<a class="lnum" href="#63" name="63">0063</a><span class="string">    ...     return dct</span><br />
+<a class="lnum" href="#64" name="64">0064</a><span class="string">    ... </span><br />
+<a class="lnum" href="#65" name="65">0065</a><span class="string">    >>> simplejson.loads('{"__complex__": true, "real": 1, "imag": 2}',</span><br />
+<a class="lnum" href="#66" name="66">0066</a><span class="string">    ...     object_hook=as_complex)</span><br />
+<a class="lnum" href="#67" name="67">0067</a><span class="string">    (1+2j)</span><br />
+<a class="lnum" href="#68" name="68">0068</a><span class="string"></span><br />
+<a class="lnum" href="#69" name="69">0069</a><span class="string">Extending JSONEncoder::</span><br />
+<a class="lnum" href="#70" name="70">0070</a><span class="string">    </span><br />
+<a class="lnum" href="#71" name="71">0071</a><span class="string">    >>> import simplejson</span><br />
+<a class="lnum" href="#72" name="72">0072</a><span class="string">    >>> class ComplexEncoder(simplejson.JSONEncoder):</span><br />
+<a class="lnum" href="#73" name="73">0073</a><span class="string">    ...     def default(self, obj):</span><br />
+<a class="lnum" href="#74" name="74">0074</a><span class="string">    ...         if isinstance(obj, complex):</span><br />
+<a class="lnum" href="#75" name="75">0075</a><span class="string">    ...             return [obj.real, obj.imag]</span><br />
+<a class="lnum" href="#76" name="76">0076</a><span class="string">    ...         return simplejson.JSONEncoder.default(self, obj)</span><br />
+<a class="lnum" href="#77" name="77">0077</a><span class="string">    ... </span><br />
+<a class="lnum" href="#78" name="78">0078</a><span class="string">    >>> dumps(2 + 1j, cls=ComplexEncoder)</span><br />
+<a class="lnum" href="#79" name="79">0079</a><span class="string">    '[2.0, 1.0]'</span><br />
+<a class="lnum" href="#80" name="80">0080</a><span class="string">    >>> ComplexEncoder().encode(2 + 1j)</span><br />
+<a class="lnum" href="#81" name="81">0081</a><span class="string">    '[2.0, 1.0]'</span><br />
+<a class="lnum" href="#82" name="82">0082</a><span class="string">    >>> list(ComplexEncoder().iterencode(2 + 1j))</span><br />
+<a class="lnum" href="#83" name="83">0083</a><span class="string">    ['[', '2.0', ', ', '1.0', ']']</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">Note that the JSON produced by this module's default settings</span><br />
+<a class="lnum" href="#87" name="87">0087</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="#88" name="88">0088</a><span class="string">"""</span><br />
+<a class="lnum" href="#89" name="89">0089</a><span class="name">__version__</span> <span class="op">=</span> <span class="string">'1.7.1'</span><br />
+<a class="lnum" href="#90" name="90">0090</a><span class="name">__all__</span> <span class="op">=</span> <span class="op">[</span><br />
+<a class="lnum" href="#91" name="91">0091</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="#92" name="92">0092</a>    <span class="string">'JSONDecoder'</span><span class="op">,</span> <span class="string">'JSONEncoder'</span><span class="op">,</span><br />
+<a class="lnum" href="#93" name="93">0093</a><span class="op">]</span><br />
+<a class="lnum" href="#94" name="94">0094</a><br />
+<a class="lnum" href="#95" name="95">0095</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="#96" name="96">0096</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="#97" name="97">0097</a><br />
+<a class="lnum" href="#98" name="98">0098</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="#99" name="99">0099</a>    <span class="name">skipkeys</span><span class="op">=</span><span class="name">False</span><span class="op">,</span><br />
+<a class="lnum" href="#100" name="100">0100</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="#101" name="101">0101</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="#102" name="102">0102</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="#103" name="103">0103</a>    <span class="name">indent</span><span class="op">=</span><span class="name">None</span><span class="op">,</span><br />
+<a class="lnum" href="#104" name="104">0104</a>    <span class="name">separators</span><span class="op">=</span><span class="name">None</span><span class="op">,</span><br />
+<a class="lnum" href="#105" name="105">0105</a>    <span class="name">encoding</span><span class="op">=</span><span class="string">'utf-8'</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">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="#109" name="109">0109</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="#110" name="110">0110</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="#111" name="111">0111</a>    <span class="string">"""</span><br />
+<a class="lnum" href="#112" name="112">0112</a><span class="string">    Serialize ``obj`` as a JSON formatted stream to ``fp`` (a</span><br />
+<a class="lnum" href="#113" name="113">0113</a><span class="string">    ``.write()``-supporting file-like object).</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">    If ``skipkeys`` is ``True`` then ``dict`` keys that are not basic types</span><br />
+<a class="lnum" href="#116" name="116">0116</a><span class="string">    (``str``, ``unicode``, ``int``, ``long``, ``float``, ``bool``, ``None``) </span><br />
+<a class="lnum" href="#117" name="117">0117</a><span class="string">    will be skipped instead of raising a ``TypeError``.</span><br />
+<a class="lnum" href="#118" name="118">0118</a><span class="string"></span><br />
+<a class="lnum" href="#119" name="119">0119</a><span class="string">    If ``ensure_ascii`` is ``False``, then the some chunks written to ``fp``</span><br />
+<a class="lnum" href="#120" name="120">0120</a><span class="string">    may be ``unicode`` instances, subject to normal Python ``str`` to</span><br />
+<a class="lnum" href="#121" name="121">0121</a><span class="string">    ``unicode`` coercion rules. Unless ``fp.write()`` explicitly</span><br />
+<a class="lnum" href="#122" name="122">0122</a><span class="string">    understands ``unicode`` (as in ``codecs.getwriter()``) this is likely</span><br />
+<a class="lnum" href="#123" name="123">0123</a><span class="string">    to cause an error.</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 ``False``, then the circular reference check</span><br />
+<a class="lnum" href="#126" name="126">0126</a><span class="string">    for container types will be skipped and a circular reference will</span><br />
+<a class="lnum" href="#127" name="127">0127</a><span class="string">    result in an ``OverflowError`` (or worse).</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 ``allow_nan`` is ``False``, then it will be a ``ValueError`` to</span><br />
+<a class="lnum" href="#130" name="130">0130</a><span class="string">    serialize out of range ``float`` values (``nan``, ``inf``, ``-inf``)</span><br />
+<a class="lnum" href="#131" name="131">0131</a><span class="string">    in strict compliance of the JSON specification, instead of using the</span><br />
+<a class="lnum" href="#132" name="132">0132</a><span class="string">    JavaScript equivalents (``NaN``, ``Infinity``, ``-Infinity``).</span><br />
+<a class="lnum" href="#133" name="133">0133</a><span class="string"></span><br />
+<a class="lnum" href="#134" name="134">0134</a><span class="string">    If ``indent`` is a non-negative integer, then JSON array elements and object</span><br />
+<a class="lnum" href="#135" name="135">0135</a><span class="string">    members will be pretty-printed with that indent level. An indent level</span><br />
+<a class="lnum" href="#136" name="136">0136</a><span class="string">    of 0 will only insert newlines. ``None`` is the most compact representation.</span><br />
+<a class="lnum" href="#137" name="137">0137</a><span class="string"></span><br />
+<a class="lnum" href="#138" name="138">0138</a><span class="string">    If ``separators`` is an ``(item_separator, dict_separator)`` tuple</span><br />
+<a class="lnum" href="#139" name="139">0139</a><span class="string">    then it will be used instead of the default ``(', ', ': ')`` separators.</span><br />
+<a class="lnum" href="#140" name="140">0140</a><span class="string">    ``(',', ':')`` is the most compact JSON representation.</span><br />
+<a class="lnum" href="#141" name="141">0141</a><span class="string"></span><br />
+<a class="lnum" href="#142" name="142">0142</a><span class="string">    ``encoding`` is the character encoding for str instances, default is UTF-8.</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">    To use a custom ``JSONEncoder`` subclass (e.g. one that overrides the</span><br />
+<a class="lnum" href="#145" name="145">0145</a><span class="string">    ``.default()`` method to serialize additional types), specify it with</span><br />
+<a class="lnum" href="#146" name="146">0146</a><span class="string">    the ``cls`` kwarg.</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="comment"># cached encoder</span><br />
+<a class="lnum" href="#149" name="149">0149</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="#150" name="150">0150</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="#151" name="151">0151</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="#152" name="152">0152</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="#153" name="153">0153</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="#154" name="154">0154</a>    <span class="keyword">else</span><span class="op">:</span><br />
+<a class="lnum" href="#155" name="155">0155</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="#156" name="156">0156</a>            <span class="name">cls</span> <span class="op">=</span> <span class="name">JSONEncoder</span><br />
+<a class="lnum" href="#157" name="157">0157</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="#158" name="158">0158</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="#159" name="159">0159</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="#160" name="160">0160</a>    <span class="comment"># could accelerate with writelines in some versions of Python, at</span><br />
+<a class="lnum" href="#161" name="161">0161</a><span class="comment"></span>    <span class="comment"># a debuggability cost</span><br />
+<a class="lnum" href="#162" name="162">0162</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="#163" name="163">0163</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="#164" name="164">0164</a><br />
+<a class="lnum" href="#165" name="165">0165</a><br />
+<a class="lnum" href="#166" name="166">0166</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="#167" name="167">0167</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="#168" name="168">0168</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="#169" name="169">0169</a>    <span class="string">"""</span><br />
+<a class="lnum" href="#170" name="170">0170</a><span class="string">    Serialize ``obj`` to a JSON formatted ``str``.</span><br />
+<a class="lnum" href="#171" name="171">0171</a><span class="string"></span><br />
+<a class="lnum" href="#172" name="172">0172</a><span class="string">    If ``skipkeys`` is ``True`` then ``dict`` keys that are not basic types</span><br />
+<a class="lnum" href="#173" name="173">0173</a><span class="string">    (``str``, ``unicode``, ``int``, ``long``, ``float``, ``bool``, ``None``) </span><br />
+<a class="lnum" href="#174" name="174">0174</a><span class="string">    will be skipped instead of raising a ``TypeError``.</span><br />
+<a class="lnum" href="#175" name="175">0175</a><span class="string"></span><br />
+<a class="lnum" href="#176" name="176">0176</a><span class="string">    If ``ensure_ascii`` is ``False``, then the return value will be a</span><br />
+<a class="lnum" href="#177" name="177">0177</a><span class="string">    ``unicode`` instance subject to normal Python ``str`` to ``unicode``</span><br />
+<a class="lnum" href="#178" name="178">0178</a><span class="string">    coercion rules instead of being escaped to an ASCII ``str``.</span><br />
+<a class="lnum" href="#179" name="179">0179</a><span class="string"></span><br />
+<a class="lnum" href="#180" name="180">0180</a><span class="string">    If ``check_circular`` is ``False``, then the circular reference check</span><br />
+<a class="lnum" href="#181" name="181">0181</a><span class="string">    for container types will be skipped and a circular reference will</span><br />
+<a class="lnum" href="#182" name="182">0182</a><span class="string">    result in an ``OverflowError`` (or worse).</span><br />
+<a class="lnum" href="#183" name="183">0183</a><span class="string"></span><br />
+<a class="lnum" href="#184" name="184">0184</a><span class="string">    If ``allow_nan`` is ``False``, then it will be a ``ValueError`` to</span><br />
+<a class="lnum" href="#185" name="185">0185</a><span class="string">    serialize out of range ``float`` values (``nan``, ``inf``, ``-inf``) in</span><br />
+<a class="lnum" href="#186" name="186">0186</a><span class="string">    strict compliance of the JSON specification, instead of using the</span><br />
+<a class="lnum" href="#187" name="187">0187</a><span class="string">    JavaScript equivalents (``NaN``, ``Infinity``, ``-Infinity``).</span><br />
+<a class="lnum" href="#188" name="188">0188</a><span class="string"></span><br />
+<a class="lnum" href="#189" name="189">0189</a><span class="string">    If ``indent`` is a non-negative integer, then JSON array elements and</span><br />
+<a class="lnum" href="#190" name="190">0190</a><span class="string">    object members will be pretty-printed with that indent level. An indent</span><br />
+<a class="lnum" href="#191" name="191">0191</a><span class="string">    level of 0 will only insert newlines. ``None`` is the most compact</span><br />
+<a class="lnum" href="#192" name="192">0192</a><span class="string">    representation.</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 ``separators`` is an ``(item_separator, dict_separator)`` tuple</span><br />
+<a class="lnum" href="#195" name="195">0195</a><span class="string">    then it will be used instead of the default ``(', ', ': ')`` separators.</span><br />
+<a class="lnum" href="#196" name="196">0196</a><span class="string">    ``(',', ':')`` is the most compact JSON representation.</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">    ``encoding`` is the character encoding for str instances, default is UTF-8.</span><br />
+<a class="lnum" href="#199" name="199">0199</a><span class="string"></span><br />
+<a class="lnum" href="#200" name="200">0200</a><span class="string">    To use a custom ``JSONEncoder`` subclass (e.g. one that overrides the</span><br />
+<a class="lnum" href="#201" name="201">0201</a><span class="string">    ``.default()`` method to serialize additional types), specify it with</span><br />
+<a class="lnum" href="#202" name="202">0202</a><span class="string">    the ``cls`` kwarg.</span><br />
+<a class="lnum" href="#203" name="203">0203</a><span class="string">    """</span><br />
+<a class="lnum" href="#204" name="204">0204</a>    <span class="comment"># cached encoder</span><br />
+<a class="lnum" href="#205" name="205">0205</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="#206" name="206">0206</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="#207" name="207">0207</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="#208" name="208">0208</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="#209" name="209">0209</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="#210" name="210">0210</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="#211" name="211">0211</a>        <span class="name">cls</span> <span class="op">=</span> <span class="name">JSONEncoder</span><br />
+<a class="lnum" href="#212" name="212">0212</a>    <span class="keyword">return</span> <span class="name">cls</span><span class="op">(</span><br />
+<a class="lnum" href="#213" name="213">0213</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="#214" name="214">0214</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="#215" name="215">0215</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="#216" name="216">0216</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="#217" name="217">0217</a><br />
+<a class="lnum" href="#218" name="218">0218</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="#219" name="219">0219</a><br />
+<a class="lnum" href="#220" name="220">0220</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="op">**</span><span class="name">kw</span><span class="op">)</span><span class="op">:</span><br />
+<a class="lnum" href="#221" name="221">0221</a>    <span class="string">"""</span><br />
+<a class="lnum" href="#222" name="222">0222</a><span class="string">    Deserialize ``fp`` (a ``.read()``-supporting file-like object containing</span><br />
+<a class="lnum" href="#223" name="223">0223</a><span class="string">    a JSON document) to a Python object.</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="string">    If the contents of ``fp`` is encoded with an ASCII based encoding other</span><br />
+<a class="lnum" href="#226" name="226">0226</a><span class="string">    than utf-8 (e.g. latin-1), then an appropriate ``encoding`` name must</span><br />
+<a class="lnum" href="#227" name="227">0227</a><span class="string">    be specified. Encodings that are not ASCII based (such as UCS-2) are</span><br />
+<a class="lnum" href="#228" name="228">0228</a><span class="string">    not allowed, and should be wrapped with</span><br />
+<a class="lnum" href="#229" name="229">0229</a><span class="string">    ``codecs.getreader(fp)(encoding)``, or simply decoded to a ``unicode``</span><br />
+<a class="lnum" href="#230" name="230">0230</a><span class="string">    object and passed to ``loads()``</span><br />
+<a class="lnum" href="#231" name="231">0231</a><span class="string"></span><br />
+<a class="lnum" href="#232" name="232">0232</a><span class="string">    ``object_hook`` is an optional function that will be called with the</span><br />
+<a class="lnum" href="#233" name="233">0233</a><span class="string">    result of any object literal decode (a ``dict``). The return value of</span><br />
+<a class="lnum" href="#234" name="234">0234</a><span class="string">    ``object_hook`` will be used instead of the ``dict``. This feature</span><br />
+<a class="lnum" href="#235" name="235">0235</a><span class="string">    can be used to implement custom decoders (e.g. JSON-RPC class hinting).</span><br />
+<a class="lnum" href="#236" name="236">0236</a><span class="string">    </span><br />
+<a class="lnum" href="#237" name="237">0237</a><span class="string">    To use a custom ``JSONDecoder`` subclass, specify it with the ``cls``</span><br />
+<a class="lnum" href="#238" name="238">0238</a><span class="string">    kwarg.</span><br />
+<a class="lnum" href="#239" name="239">0239</a><span class="string">    """</span><br />
+<a class="lnum" href="#240" name="240">0240</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="#241" name="241">0241</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> <span class="op">**</span><span class="name">kw</span><span class="op">)</span><br />
+<a class="lnum" href="#242" name="242">0242</a><br />
+<a class="lnum" href="#243" name="243">0243</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="op">**</span><span class="name">kw</span><span class="op">)</span><span class="op">:</span><br />
+<a class="lnum" href="#244" name="244">0244</a>    <span class="string">"""</span><br />
+<a class="lnum" href="#245" name="245">0245</a><span class="string">    Deserialize ``s`` (a ``str`` or ``unicode`` instance containing a JSON</span><br />
+<a class="lnum" href="#246" name="246">0246</a><span class="string">    document) to a Python object.</span><br />
+<a class="lnum" href="#247" name="247">0247</a><span class="string"></span><br />
+<a class="lnum" href="#248" name="248">0248</a><span class="string">    If ``s`` is a ``str`` instance and is encoded with an ASCII based encoding</span><br />
+<a class="lnum" href="#249" name="249">0249</a><span class="string">    other than utf-8 (e.g. latin-1) then an appropriate ``encoding`` name</span><br />
+<a class="lnum" href="#250" name="250">0250</a><span class="string">    must be specified. Encodings that are not ASCII based (such as UCS-2)</span><br />
+<a class="lnum" href="#251" name="251">0251</a><span class="string">    are not allowed and should be decoded to ``unicode`` first.</span><br />
+<a class="lnum" href="#252" name="252">0252</a><span class="string"></span><br />
+<a class="lnum" href="#253" name="253">0253</a><span class="string">    ``object_hook`` is an optional function that will be called with the</span><br />
+<a class="lnum" href="#254" name="254">0254</a><span class="string">    result of any object literal decode (a ``dict``). The return value of</span><br />
+<a class="lnum" href="#255" name="255">0255</a><span class="string">    ``object_hook`` will be used instead of the ``dict``. This feature</span><br />
+<a class="lnum" href="#256" name="256">0256</a><span class="string">    can be used to implement custom decoders (e.g. JSON-RPC class hinting).</span><br />
+<a class="lnum" href="#257" name="257">0257</a><span class="string"></span><br />
+<a class="lnum" href="#258" name="258">0258</a><span class="string">    To use a custom ``JSONDecoder`` subclass, specify it with the ``cls``</span><br />
+<a class="lnum" href="#259" name="259">0259</a><span class="string">    kwarg.</span><br />
+<a class="lnum" href="#260" name="260">0260</a><span class="string">    """</span><br />
+<a class="lnum" href="#261" name="261">0261</a>    <span class="keyword">if</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> <span class="keyword">not</span> <span class="name">kw</span><span class="op">:</span><br />
+<a class="lnum" href="#262" name="262">0262</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="#263" name="263">0263</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="#264" name="264">0264</a>        <span class="name">cls</span> <span class="op">=</span> <span class="name">JSONDecoder</span><br />
+<a class="lnum" href="#265" name="265">0265</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="#266" name="266">0266</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="#267" name="267">0267</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="#268" name="268">0268</a><br />
+<a class="lnum" href="#269" name="269">0269</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="#270" name="270">0270</a>    <span class="string">"""</span><br />
+<a class="lnum" href="#271" name="271">0271</a><span class="string">    json-py API compatibility hook. Use loads(s) instead.</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="keyword">import</span> <span class="name">warnings</span><br />
+<a class="lnum" href="#274" name="274">0274</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="#275" name="275">0275</a>        <span class="name">DeprecationWarning</span><span class="op">)</span><br />
+<a class="lnum" href="#276" name="276">0276</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="#277" name="277">0277</a><br />
+<a class="lnum" href="#278" name="278">0278</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="#279" name="279">0279</a>    <span class="string">"""</span><br />
+<a class="lnum" href="#280" name="280">0280</a><span class="string">    json-py API compatibility hook. Use dumps(s) instead.</span><br />
+<a class="lnum" href="#281" name="281">0281</a><span class="string">    """</span><br />
+<a class="lnum" href="#282" name="282">0282</a>    <span class="keyword">import</span> <span class="name">warnings</span><br />
+<a class="lnum" href="#283" name="283">0283</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="#284" name="284">0284</a>        <span class="name">DeprecationWarning</span><span class="op">)</span><br />
+<a class="lnum" href="#285" name="285">0285</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
--- /dev/null
+<html><head><title>/Users/bob/src/simplejson/simplejson/decoder.py</title>
+ <script type="text/javascript"><!--
+
+function show_line_range() {
+ var href = document.location.href;
+ if (href.indexOf('?') == -1) {
+ return;
+ }
+ var qs = href.substring(href.indexOf('?')+1);
+ if (qs.indexOf('#') >= 0) {
+ qs = qs.substring(0, qs.indexOf('#'));
+ }
+ var first = qs.match(/f=(\d+)/)[1];
+ var last = qs.match(/l=(\d+)/)[1];
+ if (! first || ! last) {
+ return;
+ }
+ var anchors = document.getElementsByTagName('A');
+ var container = document.createElement('DIV');
+ container.className = 'highlighted';
+ var children = [];
+ var start = null;
+ var parent = null;
+ var highlight = false;
+ for (var i = 0; i < anchors.length; i++) {
+ var el = anchors[i];
+ if (el.getAttribute('name') == first) {
+ start = el.previousSibling;
+ parent = el.parentNode;
+ highlight = true;
+ }
+ if (el.getAttribute('name') == last) {
+ break;
+ }
+ if (highlight) {
+ children[children.length] = el;
+ el = el.nextSibling;
+ while (el && el.tagName != 'A') {
+ children[children.length] = el;
+ el = el.nextSibling;
+ }
+ }
+ }
+ for (i=0; i<children.length; i++) {
+ container.appendChild(children[i]);
+ }
+ if (start) {
+ start.parentNode.insertBefore(container, start.nextSibling);
+ } else {
+ parent.insertBefore(container, parent.childNodes[0]);
+ }
+}
+
+ // --></script>
+ <style>
+ div.python {
+ color: #333
+ }
+ div.python a.lnum {
+ color: #555;
+ background-color: #eee;
+ border-right: 1px solid #999;
+ padding-right: 2px;
+ margin-right: 4px;
+ }
+ div.python span.comment { color: #933 }
+ div.python span.keyword { color: #a3e; font-weight: bold }
+ div.python span.op { color: #c96 }
+ div.python span.string { color: #6a6 }
+ div.python span.name { }
+ div.python span.text { color: #333 }
+ div.highlighted { background-color: #ff9; border: 1px solid #009 }
+ </style></head><body onload="show_line_range()"><div class="python"><code><a class="lnum" href="#1" name="1">0001</a><span class="string">"""</span><br />
+<a class="lnum" href="#2" name="2">0002</a><span class="string">Implementation of JSONDecoder</span><br />
+<a class="lnum" href="#3" name="3">0003</a><span class="string">"""</span><br />
+<a class="lnum" href="#4" name="4">0004</a><span class="keyword">import</span> <span class="name">re</span><br />
+<a class="lnum" href="#5" name="5">0005</a><br />
+<a class="lnum" href="#6" name="6">0006</a><span class="keyword">from</span> <span class="name">simplejson</span><span class="op">.</span><span class="name">scanner</span> <span class="keyword">import</span> <span class="name">Scanner</span><span class="op">,</span> <span class="name">pattern</span><br />
+<a class="lnum" href="#7" name="7">0007</a><br />
+<a class="lnum" href="#8" name="8">0008</a><span class="name">FLAGS</span> <span class="op">=</span> <span class="name">re</span><span class="op">.</span><span class="name">VERBOSE</span> <span class="op">|</span> <span class="name">re</span><span class="op">.</span><span class="name">MULTILINE</span> <span class="op">|</span> <span class="name">re</span><span class="op">.</span><span class="name">DOTALL</span><br />
+<a class="lnum" href="#9" name="9">0009</a><br />
+<a class="lnum" href="#10" name="10">0010</a><span class="keyword">def</span> <span class="name">_floatconstants</span><span class="op">(</span><span class="op">)</span><span class="op">:</span><br />
+<a class="lnum" href="#11" name="11">0011</a>    <span class="keyword">import</span> <span class="name">struct</span><br />
+<a class="lnum" href="#12" name="12">0012</a>    <span class="keyword">import</span> <span class="name">sys</span><br />
+<a class="lnum" href="#13" name="13">0013</a>    <span class="name">_BYTES</span> <span class="op">=</span> <span class="string">'7FF80000000000007FF0000000000000'</span><span class="op">.</span><span class="name">decode</span><span class="op">(</span><span class="string">'hex'</span><span class="op">)</span><br />
+<a class="lnum" href="#14" name="14">0014</a>    <span class="keyword">if</span> <span class="name">sys</span><span class="op">.</span><span class="name">byteorder</span> <span class="op">!=</span> <span class="string">'big'</span><span class="op">:</span><br />
+<a class="lnum" href="#15" name="15">0015</a>        <span class="name">_BYTES</span> <span class="op">=</span> <span class="name">_BYTES</span><span class="op">[</span><span class="op">:</span><span class="number">8</span><span class="op">]</span><span class="op">[</span><span class="op">:</span><span class="op">:</span><span class="op">-</span><span class="number">1</span><span class="op">]</span> <span class="op">+</span> <span class="name">_BYTES</span><span class="op">[</span><span class="number">8</span><span class="op">:</span><span class="op">]</span><span class="op">[</span><span class="op">:</span><span class="op">:</span><span class="op">-</span><span class="number">1</span><span class="op">]</span><br />
+<a class="lnum" href="#16" name="16">0016</a>    <span class="name">nan</span><span class="op">,</span> <span class="name">inf</span> <span class="op">=</span> <span class="name">struct</span><span class="op">.</span><span class="name">unpack</span><span class="op">(</span><span class="string">'dd'</span><span class="op">,</span> <span class="name">_BYTES</span><span class="op">)</span><br />
+<a class="lnum" href="#17" name="17">0017</a>    <span class="keyword">return</span> <span class="name">nan</span><span class="op">,</span> <span class="name">inf</span><span class="op">,</span> <span class="op">-</span><span class="name">inf</span><br />
+<a class="lnum" href="#18" name="18">0018</a><br />
+<a class="lnum" href="#19" name="19">0019</a><span class="name">NaN</span><span class="op">,</span> <span class="name">PosInf</span><span class="op">,</span> <span class="name">NegInf</span> <span class="op">=</span> <span class="name">_floatconstants</span><span class="op">(</span><span class="op">)</span><br />
+<a class="lnum" href="#20" name="20">0020</a><br />
+<a class="lnum" href="#21" name="21">0021</a><span class="keyword">def</span> <span class="name">linecol</span><span class="op">(</span><span class="name">doc</span><span class="op">,</span> <span class="name">pos</span><span class="op">)</span><span class="op">:</span><br />
+<a class="lnum" href="#22" name="22">0022</a>    <span class="name">lineno</span> <span class="op">=</span> <span class="name">doc</span><span class="op">.</span><span class="name">count</span><span class="op">(</span><span class="string">'\n'</span><span class="op">,</span> <span class="number">0</span><span class="op">,</span> <span class="name">pos</span><span class="op">)</span> <span class="op">+</span> <span class="number">1</span><br />
+<a class="lnum" href="#23" name="23">0023</a>    <span class="keyword">if</span> <span class="name">lineno</span> <span class="op">==</span> <span class="number">1</span><span class="op">:</span><br />
+<a class="lnum" href="#24" name="24">0024</a>        <span class="name">colno</span> <span class="op">=</span> <span class="name">pos</span><br />
+<a class="lnum" href="#25" name="25">0025</a>    <span class="keyword">else</span><span class="op">:</span><br />
+<a class="lnum" href="#26" name="26">0026</a>        <span class="name">colno</span> <span class="op">=</span> <span class="name">pos</span> <span class="op">-</span> <span class="name">doc</span><span class="op">.</span><span class="name">rindex</span><span class="op">(</span><span class="string">'\n'</span><span class="op">,</span> <span class="number">0</span><span class="op">,</span> <span class="name">pos</span><span class="op">)</span><br />
+<a class="lnum" href="#27" name="27">0027</a>    <span class="keyword">return</span> <span class="name">lineno</span><span class="op">,</span> <span class="name">colno</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">errmsg</span><span class="op">(</span><span class="name">msg</span><span class="op">,</span> <span class="name">doc</span><span class="op">,</span> <span class="name">pos</span><span class="op">,</span> <span class="name">end</span><span class="op">=</span><span class="name">None</span><span class="op">)</span><span class="op">:</span><br />
+<a class="lnum" href="#30" name="30">0030</a>    <span class="name">lineno</span><span class="op">,</span> <span class="name">colno</span> <span class="op">=</span> <span class="name">linecol</span><span class="op">(</span><span class="name">doc</span><span class="op">,</span> <span class="name">pos</span><span class="op">)</span><br />
+<a class="lnum" href="#31" name="31">0031</a>    <span class="keyword">if</span> <span class="name">end</span> <span class="keyword">is</span> <span class="name">None</span><span class="op">:</span><br />
+<a class="lnum" href="#32" name="32">0032</a>        <span class="keyword">return</span> <span class="string">'%s: line %d column %d (char %d)'</span> <span class="op">%</span> <span class="op">(</span><span class="name">msg</span><span class="op">,</span> <span class="name">lineno</span><span class="op">,</span> <span class="name">colno</span><span class="op">,</span> <span class="name">pos</span><span class="op">)</span><br />
+<a class="lnum" href="#33" name="33">0033</a>    <span class="name">endlineno</span><span class="op">,</span> <span class="name">endcolno</span> <span class="op">=</span> <span class="name">linecol</span><span class="op">(</span><span class="name">doc</span><span class="op">,</span> <span class="name">end</span><span class="op">)</span><br />
+<a class="lnum" href="#34" name="34">0034</a>    <span class="keyword">return</span> <span class="string">'%s: line %d column %d - line %d column %d (char %d - %d)'</span> <span class="op">%</span> <span class="op">(</span><br />
+<a class="lnum" href="#35" name="35">0035</a>        <span class="name">msg</span><span class="op">,</span> <span class="name">lineno</span><span class="op">,</span> <span class="name">colno</span><span class="op">,</span> <span class="name">endlineno</span><span class="op">,</span> <span class="name">endcolno</span><span class="op">,</span> <span class="name">pos</span><span class="op">,</span> <span class="name">end</span><span class="op">)</span><br />
+<a class="lnum" href="#36" name="36">0036</a><br />
+<a class="lnum" href="#37" name="37">0037</a><span class="name">_CONSTANTS</span> <span class="op">=</span> <span class="op">{</span><br />
+<a class="lnum" href="#38" name="38">0038</a>    <span class="string">'-Infinity'</span><span class="op">:</span> <span class="name">NegInf</span><span class="op">,</span><br />
+<a class="lnum" href="#39" name="39">0039</a>    <span class="string">'Infinity'</span><span class="op">:</span> <span class="name">PosInf</span><span class="op">,</span><br />
+<a class="lnum" href="#40" name="40">0040</a>    <span class="string">'NaN'</span><span class="op">:</span> <span class="name">NaN</span><span class="op">,</span><br />
+<a class="lnum" href="#41" name="41">0041</a>    <span class="string">'true'</span><span class="op">:</span> <span class="name">True</span><span class="op">,</span><br />
+<a class="lnum" href="#42" name="42">0042</a>    <span class="string">'false'</span><span class="op">:</span> <span class="name">False</span><span class="op">,</span><br />
+<a class="lnum" href="#43" name="43">0043</a>    <span class="string">'null'</span><span class="op">:</span> <span class="name">None</span><span class="op">,</span><br />
+<a class="lnum" href="#44" name="44">0044</a><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">def</span> <span class="name">JSONConstant</span><span class="op">(</span><span class="name">match</span><span class="op">,</span> <span class="name">context</span><span class="op">,</span> <span class="name">c</span><span class="op">=</span><span class="name">_CONSTANTS</span><span class="op">)</span><span class="op">:</span><br />
+<a class="lnum" href="#47" name="47">0047</a>    <span class="keyword">return</span> <span class="name">c</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><span class="op">,</span> <span class="name">None</span><br />
+<a class="lnum" href="#48" name="48">0048</a><span class="name">pattern</span><span class="op">(</span><span class="string">'(-?Infinity|NaN|true|false|null)'</span><span class="op">)</span><span class="op">(</span><span class="name">JSONConstant</span><span class="op">)</span><br />
+<a class="lnum" href="#49" name="49">0049</a><br />
+<a class="lnum" href="#50" name="50">0050</a><span class="keyword">def</span> <span class="name">JSONNumber</span><span class="op">(</span><span class="name">match</span><span class="op">,</span> <span class="name">context</span><span class="op">)</span><span class="op">:</span><br />
+<a class="lnum" href="#51" name="51">0051</a>    <span class="name">match</span> <span class="op">=</span> <span class="name">JSONNumber</span><span class="op">.</span><span class="name">regex</span><span class="op">.</span><span class="name">match</span><span class="op">(</span><span class="name">match</span><span class="op">.</span><span class="name">string</span><span class="op">,</span> <span class="op">*</span><span class="name">match</span><span class="op">.</span><span class="name">span</span><span class="op">(</span><span class="op">)</span><span class="op">)</span><br />
+<a class="lnum" href="#52" name="52">0052</a>    <span class="name">integer</span><span class="op">,</span> <span class="name">frac</span><span class="op">,</span> <span class="name">exp</span> <span class="op">=</span> <span class="name">match</span><span class="op">.</span><span class="name">groups</span><span class="op">(</span><span class="op">)</span><br />
+<a class="lnum" href="#53" name="53">0053</a>    <span class="keyword">if</span> <span class="name">frac</span> <span class="keyword">or</span> <span class="name">exp</span><span class="op">:</span><br />
+<a class="lnum" href="#54" name="54">0054</a>        <span class="name">res</span> <span class="op">=</span> <span class="name">float</span><span class="op">(</span><span class="name">integer</span> <span class="op">+</span> <span class="op">(</span><span class="name">frac</span> <span class="keyword">or</span> <span class="string">''</span><span class="op">)</span> <span class="op">+</span> <span class="op">(</span><span class="name">exp</span> <span class="keyword">or</span> <span class="string">''</span><span class="op">)</span><span class="op">)</span><br />
+<a class="lnum" href="#55" name="55">0055</a>    <span class="keyword">else</span><span class="op">:</span><br />
+<a class="lnum" href="#56" name="56">0056</a>        <span class="name">res</span> <span class="op">=</span> <span class="name">int</span><span class="op">(</span><span class="name">integer</span><span class="op">)</span><br />
+<a class="lnum" href="#57" name="57">0057</a>    <span class="keyword">return</span> <span class="name">res</span><span class="op">,</span> <span class="name">None</span><br />
+<a class="lnum" href="#58" name="58">0058</a><span class="name">pattern</span><span class="op">(</span><span class="string">r'(-?(?:0|[1-9]\d*))(\.\d+)?([eE][-+]?\d+)?'</span><span class="op">)</span><span class="op">(</span><span class="name">JSONNumber</span><span class="op">)</span><br />
+<a class="lnum" href="#59" name="59">0059</a><br />
+<a class="lnum" href="#60" name="60">0060</a><span class="name">STRINGCHUNK</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> <span class="name">FLAGS</span><span class="op">)</span><br />
+<a class="lnum" href="#61" name="61">0061</a><span class="name">BACKSLASH</span> <span class="op">=</span> <span class="op">{</span><br />
+<a class="lnum" href="#62" name="62">0062</a>    <span class="string">'"'</span><span class="op">:</span> <span class="string">u'"'</span><span class="op">,</span> <span class="string">'\\'</span><span class="op">:</span> <span class="string">u'\\'</span><span class="op">,</span> <span class="string">'/'</span><span class="op">:</span> <span class="string">u'/'</span><span class="op">,</span><br />
+<a class="lnum" href="#63" name="63">0063</a>    <span class="string">'b'</span><span class="op">:</span> <span class="string">u'\b'</span><span class="op">,</span> <span class="string">'f'</span><span class="op">:</span> <span class="string">u'\f'</span><span class="op">,</span> <span class="string">'n'</span><span class="op">:</span> <span class="string">u'\n'</span><span class="op">,</span> <span class="string">'r'</span><span class="op">:</span> <span class="string">u'\r'</span><span class="op">,</span> <span class="string">'t'</span><span class="op">:</span> <span class="string">u'\t'</span><span class="op">,</span><br />
+<a class="lnum" href="#64" name="64">0064</a><span class="op">}</span><br />
+<a class="lnum" href="#65" name="65">0065</a><br />
+<a class="lnum" href="#66" name="66">0066</a><span class="name">DEFAULT_ENCODING</span> <span class="op">=</span> <span class="string">"utf-8"</span><br />
+<a class="lnum" href="#67" name="67">0067</a><br />
+<a class="lnum" href="#68" name="68">0068</a><span class="keyword">def</span> <span class="name">scanstring</span><span class="op">(</span><span class="name">s</span><span class="op">,</span> <span class="name">end</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">_b</span><span class="op">=</span><span class="name">BACKSLASH</span><span class="op">,</span> <span class="name">_m</span><span class="op">=</span><span class="name">STRINGCHUNK</span><span class="op">.</span><span class="name">match</span><span class="op">)</span><span class="op">:</span><br />
+<a class="lnum" href="#69" name="69">0069</a>    <span class="keyword">if</span> <span class="name">encoding</span> <span class="keyword">is</span> <span class="name">None</span><span class="op">:</span><br />
+<a class="lnum" href="#70" name="70">0070</a>        <span class="name">encoding</span> <span class="op">=</span> <span class="name">DEFAULT_ENCODING</span><br />
+<a class="lnum" href="#71" name="71">0071</a>    <span class="name">chunks</span> <span class="op">=</span> <span class="op">[</span><span class="op">]</span><br />
+<a class="lnum" href="#72" name="72">0072</a>    <span class="name">_append</span> <span class="op">=</span> <span class="name">chunks</span><span class="op">.</span><span class="name">append</span><br />
+<a class="lnum" href="#73" name="73">0073</a>    <span class="name">begin</span> <span class="op">=</span> <span class="name">end</span> <span class="op">-</span> <span class="number">1</span><br />
+<a class="lnum" href="#74" name="74">0074</a>    <span class="keyword">while</span> <span class="number">1</span><span class="op">:</span><br />
+<a class="lnum" href="#75" name="75">0075</a>        <span class="name">chunk</span> <span class="op">=</span> <span class="name">_m</span><span class="op">(</span><span class="name">s</span><span class="op">,</span> <span class="name">end</span><span class="op">)</span><br />
+<a class="lnum" href="#76" name="76">0076</a>        <span class="keyword">if</span> <span class="name">chunk</span> <span class="keyword">is</span> <span class="name">None</span><span class="op">:</span><br />
+<a class="lnum" href="#77" name="77">0077</a>            <span class="keyword">raise</span> <span class="name">ValueError</span><span class="op">(</span><br />
+<a class="lnum" href="#78" name="78">0078</a>                <span class="name">errmsg</span><span class="op">(</span><span class="string">"Unterminated string starting at"</span><span class="op">,</span> <span class="name">s</span><span class="op">,</span> <span class="name">begin</span><span class="op">)</span><span class="op">)</span><br />
+<a class="lnum" href="#79" name="79">0079</a>        <span class="name">end</span> <span class="op">=</span> <span class="name">chunk</span><span class="op">.</span><span class="name">end</span><span class="op">(</span><span class="op">)</span><br />
+<a class="lnum" href="#80" name="80">0080</a>        <span class="name">content</span><span class="op">,</span> <span class="name">terminator</span> <span class="op">=</span> <span class="name">chunk</span><span class="op">.</span><span class="name">groups</span><span class="op">(</span><span class="op">)</span><br />
+<a class="lnum" href="#81" name="81">0081</a>        <span class="keyword">if</span> <span class="name">content</span><span class="op">:</span><br />
+<a class="lnum" href="#82" name="82">0082</a>            <span class="keyword">if</span> <span class="keyword">not</span> <span class="name">isinstance</span><span class="op">(</span><span class="name">content</span><span class="op">,</span> <span class="name">unicode</span><span class="op">)</span><span class="op">:</span><br />
+<a class="lnum" href="#83" name="83">0083</a>                <span class="name">content</span> <span class="op">=</span> <span class="name">unicode</span><span class="op">(</span><span class="name">content</span><span class="op">,</span> <span class="name">encoding</span><span class="op">)</span><br />
+<a class="lnum" href="#84" name="84">0084</a>            <span class="name">_append</span><span class="op">(</span><span class="name">content</span><span class="op">)</span><br />
+<a class="lnum" href="#85" name="85">0085</a>        <span class="keyword">if</span> <span class="name">terminator</span> <span class="op">==</span> <span class="string">'"'</span><span class="op">:</span><br />
+<a class="lnum" href="#86" name="86">0086</a>            <span class="keyword">break</span><br />
+<a class="lnum" href="#87" name="87">0087</a>        <span class="keyword">try</span><span class="op">:</span><br />
+<a class="lnum" href="#88" name="88">0088</a>            <span class="name">esc</span> <span class="op">=</span> <span class="name">s</span><span class="op">[</span><span class="name">end</span><span class="op">]</span><br />
+<a class="lnum" href="#89" name="89">0089</a>        <span class="keyword">except</span> <span class="name">IndexError</span><span class="op">:</span><br />
+<a class="lnum" href="#90" name="90">0090</a>            <span class="keyword">raise</span> <span class="name">ValueError</span><span class="op">(</span><br />
+<a class="lnum" href="#91" name="91">0091</a>                <span class="name">errmsg</span><span class="op">(</span><span class="string">"Unterminated string starting at"</span><span class="op">,</span> <span class="name">s</span><span class="op">,</span> <span class="name">begin</span><span class="op">)</span><span class="op">)</span><br />
+<a class="lnum" href="#92" name="92">0092</a>        <span class="keyword">if</span> <span class="name">esc</span> <span class="op">!=</span> <span class="string">'u'</span><span class="op">:</span><br />
+<a class="lnum" href="#93" name="93">0093</a>            <span class="keyword">try</span><span class="op">:</span><br />
+<a class="lnum" href="#94" name="94">0094</a>                <span class="name">m</span> <span class="op">=</span> <span class="name">_b</span><span class="op">[</span><span class="name">esc</span><span class="op">]</span><br />
+<a class="lnum" href="#95" name="95">0095</a>            <span class="keyword">except</span> <span class="name">KeyError</span><span class="op">:</span><br />
+<a class="lnum" href="#96" name="96">0096</a>                <span class="keyword">raise</span> <span class="name">ValueError</span><span class="op">(</span><br />
+<a class="lnum" href="#97" name="97">0097</a>                    <span class="name">errmsg</span><span class="op">(</span><span class="string">"Invalid \\escape: %r"</span> <span class="op">%</span> <span class="op">(</span><span class="name">esc</span><span class="op">,</span><span class="op">)</span><span class="op">,</span> <span class="name">s</span><span class="op">,</span> <span class="name">end</span><span class="op">)</span><span class="op">)</span><br />
+<a class="lnum" href="#98" name="98">0098</a>            <span class="name">end</span> <span class="op">+=</span> <span class="number">1</span><br />
+<a class="lnum" href="#99" name="99">0099</a>        <span class="keyword">else</span><span class="op">:</span><br />
+<a class="lnum" href="#100" name="100">0100</a>            <span class="name">esc</span> <span class="op">=</span> <span class="name">s</span><span class="op">[</span><span class="name">end</span> <span class="op">+</span> <span class="number">1</span><span class="op">:</span><span class="name">end</span> <span class="op">+</span> <span class="number">5</span><span class="op">]</span><br />
+<a class="lnum" href="#101" name="101">0101</a>            <span class="keyword">try</span><span class="op">:</span><br />
+<a class="lnum" href="#102" name="102">0102</a>                <span class="name">m</span> <span class="op">=</span> <span class="name">unichr</span><span class="op">(</span><span class="name">int</span><span class="op">(</span><span class="name">esc</span><span class="op">,</span> <span class="number">16</span><span class="op">)</span><span class="op">)</span><br />
+<a class="lnum" href="#103" name="103">0103</a>                <span class="keyword">if</span> <span class="name">len</span><span class="op">(</span><span class="name">esc</span><span class="op">)</span> <span class="op">!=</span> <span class="number">4</span> <span class="keyword">or</span> <span class="keyword">not</span> <span class="name">esc</span><span class="op">.</span><span class="name">isalnum</span><span class="op">(</span><span class="op">)</span><span class="op">:</span><br />
+<a class="lnum" href="#104" name="104">0104</a>                    <span class="keyword">raise</span> <span class="name">ValueError</span><br />
+<a class="lnum" href="#105" name="105">0105</a>            <span class="keyword">except</span> <span class="name">ValueError</span><span class="op">:</span><br />
+<a class="lnum" href="#106" name="106">0106</a>                <span class="keyword">raise</span> <span class="name">ValueError</span><span class="op">(</span><span class="name">errmsg</span><span class="op">(</span><span class="string">"Invalid \\uXXXX escape"</span><span class="op">,</span> <span class="name">s</span><span class="op">,</span> <span class="name">end</span><span class="op">)</span><span class="op">)</span><br />
+<a class="lnum" href="#107" name="107">0107</a>            <span class="name">end</span> <span class="op">+=</span> <span class="number">5</span><br />
+<a class="lnum" href="#108" name="108">0108</a>        <span class="name">_append</span><span class="op">(</span><span class="name">m</span><span class="op">)</span><br />
+<a class="lnum" href="#109" name="109">0109</a>    <span class="keyword">return</span> <span class="string">u''</span><span class="op">.</span><span class="name">join</span><span class="op">(</span><span class="name">chunks</span><span class="op">)</span><span class="op">,</span> <span class="name">end</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">JSONString</span><span class="op">(</span><span class="name">match</span><span class="op">,</span> <span class="name">context</span><span class="op">)</span><span class="op">:</span><br />
+<a class="lnum" href="#112" name="112">0112</a>    <span class="name">encoding</span> <span class="op">=</span> <span class="name">getattr</span><span class="op">(</span><span class="name">context</span><span class="op">,</span> <span class="string">'encoding'</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="keyword">return</span> <span class="name">scanstring</span><span class="op">(</span><span class="name">match</span><span class="op">.</span><span class="name">string</span><span class="op">,</span> <span class="name">match</span><span class="op">.</span><span class="name">end</span><span class="op">(</span><span class="op">)</span><span class="op">,</span> <span class="name">encoding</span><span class="op">)</span><br />
+<a class="lnum" href="#114" name="114">0114</a><span class="name">pattern</span><span class="op">(</span><span class="string">r'"'</span><span class="op">)</span><span class="op">(</span><span class="name">JSONString</span><span class="op">)</span><br />
+<a class="lnum" href="#115" name="115">0115</a><br />
+<a class="lnum" href="#116" name="116">0116</a><span class="name">WHITESPACE</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'\s*'</span><span class="op">,</span> <span class="name">FLAGS</span><span class="op">)</span><br />
+<a class="lnum" href="#117" name="117">0117</a><br />
+<a class="lnum" href="#118" name="118">0118</a><span class="keyword">def</span> <span class="name">JSONObject</span><span class="op">(</span><span class="name">match</span><span class="op">,</span> <span class="name">context</span><span class="op">,</span> <span class="name">_w</span><span class="op">=</span><span class="name">WHITESPACE</span><span class="op">.</span><span class="name">match</span><span class="op">)</span><span class="op">:</span><br />
+<a class="lnum" href="#119" name="119">0119</a>    <span class="name">pairs</span> <span class="op">=</span> <span class="op">{</span><span class="op">}</span><br />
+<a class="lnum" href="#120" name="120">0120</a>    <span class="name">s</span> <span class="op">=</span> <span class="name">match</span><span class="op">.</span><span class="name">string</span><br />
+<a class="lnum" href="#121" name="121">0121</a>    <span class="name">end</span> <span class="op">=</span> <span class="name">_w</span><span class="op">(</span><span class="name">s</span><span class="op">,</span> <span class="name">match</span><span class="op">.</span><span class="name">end</span><span class="op">(</span><span class="op">)</span><span class="op">)</span><span class="op">.</span><span class="name">end</span><span class="op">(</span><span class="op">)</span><br />
+<a class="lnum" href="#122" name="122">0122</a>    <span class="name">nextchar</span> <span class="op">=</span> <span class="name">s</span><span class="op">[</span><span class="name">end</span><span class="op">:</span><span class="name">end</span> <span class="op">+</span> <span class="number">1</span><span class="op">]</span><br />
+<a class="lnum" href="#123" name="123">0123</a>    <span class="comment"># trivial empty object</span><br />
+<a class="lnum" href="#124" name="124">0124</a><span class="comment"></span>    <span class="keyword">if</span> <span class="name">nextchar</span> <span class="op">==</span> <span class="string">'}'</span><span class="op">:</span><br />
+<a class="lnum" href="#125" name="125">0125</a>        <span class="keyword">return</span> <span class="name">pairs</span><span class="op">,</span> <span class="name">end</span> <span class="op">+</span> <span class="number">1</span><br />
+<a class="lnum" href="#126" name="126">0126</a>    <span class="keyword">if</span> <span class="name">nextchar</span> <span class="op">!=</span> <span class="string">'"'</span><span class="op">:</span><br />
+<a class="lnum" href="#127" name="127">0127</a>        <span class="keyword">raise</span> <span class="name">ValueError</span><span class="op">(</span><span class="name">errmsg</span><span class="op">(</span><span class="string">"Expecting property name"</span><span class="op">,</span> <span class="name">s</span><span class="op">,</span> <span class="name">end</span><span class="op">)</span><span class="op">)</span><br />
+<a class="lnum" href="#128" name="128">0128</a>    <span class="name">end</span> <span class="op">+=</span> <span class="number">1</span><br />
+<a class="lnum" href="#129" name="129">0129</a>    <span class="name">encoding</span> <span class="op">=</span> <span class="name">getattr</span><span class="op">(</span><span class="name">context</span><span class="op">,</span> <span class="string">'encoding'</span><span class="op">,</span> <span class="name">None</span><span class="op">)</span><br />
+<a class="lnum" href="#130" name="130">0130</a>    <span class="name">iterscan</span> <span class="op">=</span> <span class="name">JSONScanner</span><span class="op">.</span><span class="name">iterscan</span><br />
+<a class="lnum" href="#131" name="131">0131</a>    <span class="keyword">while</span> <span class="name">True</span><span class="op">:</span><br />
+<a class="lnum" href="#132" name="132">0132</a>        <span class="name">key</span><span class="op">,</span> <span class="name">end</span> <span class="op">=</span> <span class="name">scanstring</span><span class="op">(</span><span class="name">s</span><span class="op">,</span> <span class="name">end</span><span class="op">,</span> <span class="name">encoding</span><span class="op">)</span><br />
+<a class="lnum" href="#133" name="133">0133</a>        <span class="name">end</span> <span class="op">=</span> <span class="name">_w</span><span class="op">(</span><span class="name">s</span><span class="op">,</span> <span class="name">end</span><span class="op">)</span><span class="op">.</span><span class="name">end</span><span class="op">(</span><span class="op">)</span><br />
+<a class="lnum" href="#134" name="134">0134</a>        <span class="keyword">if</span> <span class="name">s</span><span class="op">[</span><span class="name">end</span><span class="op">:</span><span class="name">end</span> <span class="op">+</span> <span class="number">1</span><span class="op">]</span> <span class="op">!=</span> <span class="string">':'</span><span class="op">:</span><br />
+<a class="lnum" href="#135" name="135">0135</a>            <span class="keyword">raise</span> <span class="name">ValueError</span><span class="op">(</span><span class="name">errmsg</span><span class="op">(</span><span class="string">"Expecting : delimiter"</span><span class="op">,</span> <span class="name">s</span><span class="op">,</span> <span class="name">end</span><span class="op">)</span><span class="op">)</span><br />
+<a class="lnum" href="#136" name="136">0136</a>        <span class="name">end</span> <span class="op">=</span> <span class="name">_w</span><span class="op">(</span><span class="name">s</span><span class="op">,</span> <span class="name">end</span> <span class="op">+</span> <span class="number">1</span><span class="op">)</span><span class="op">.</span><span class="name">end</span><span class="op">(</span><span class="op">)</span><br />
+<a class="lnum" href="#137" name="137">0137</a>        <span class="keyword">try</span><span class="op">:</span><br />
+<a class="lnum" href="#138" name="138">0138</a>            <span class="name">value</span><span class="op">,</span> <span class="name">end</span> <span class="op">=</span> <span class="name">iterscan</span><span class="op">(</span><span class="name">s</span><span class="op">,</span> <span class="name">idx</span><span class="op">=</span><span class="name">end</span><span class="op">,</span> <span class="name">context</span><span class="op">=</span><span class="name">context</span><span class="op">)</span><span class="op">.</span><span class="name">next</span><span class="op">(</span><span class="op">)</span><br />
+<a class="lnum" href="#139" name="139">0139</a>        <span class="keyword">except</span> <span class="name">StopIteration</span><span class="op">:</span><br />
+<a class="lnum" href="#140" name="140">0140</a>            <span class="keyword">raise</span> <span class="name">ValueError</span><span class="op">(</span><span class="name">errmsg</span><span class="op">(</span><span class="string">"Expecting object"</span><span class="op">,</span> <span class="name">s</span><span class="op">,</span> <span class="name">end</span><span class="op">)</span><span class="op">)</span><br />
+<a class="lnum" href="#141" name="141">0141</a>        <span class="name">pairs</span><span class="op">[</span><span class="name">key</span><span class="op">]</span> <span class="op">=</span> <span class="name">value</span><br />
+<a class="lnum" href="#142" name="142">0142</a>        <span class="name">end</span> <span class="op">=</span> <span class="name">_w</span><span class="op">(</span><span class="name">s</span><span class="op">,</span> <span class="name">end</span><span class="op">)</span><span class="op">.</span><span class="name">end</span><span class="op">(</span><span class="op">)</span><br />
+<a class="lnum" href="#143" name="143">0143</a>        <span class="name">nextchar</span> <span class="op">=</span> <span class="name">s</span><span class="op">[</span><span class="name">end</span><span class="op">:</span><span class="name">end</span> <span class="op">+</span> <span class="number">1</span><span class="op">]</span><br />
+<a class="lnum" href="#144" name="144">0144</a>        <span class="name">end</span> <span class="op">+=</span> <span class="number">1</span><br />
+<a class="lnum" href="#145" name="145">0145</a>        <span class="keyword">if</span> <span class="name">nextchar</span> <span class="op">==</span> <span class="string">'}'</span><span class="op">:</span><br />
+<a class="lnum" href="#146" name="146">0146</a>            <span class="keyword">break</span><br />
+<a class="lnum" href="#147" name="147">0147</a>        <span class="keyword">if</span> <span class="name">nextchar</span> <span class="op">!=</span> <span class="string">','</span><span class="op">:</span><br />
+<a class="lnum" href="#148" name="148">0148</a>            <span class="keyword">raise</span> <span class="name">ValueError</span><span class="op">(</span><span class="name">errmsg</span><span class="op">(</span><span class="string">"Expecting , delimiter"</span><span class="op">,</span> <span class="name">s</span><span class="op">,</span> <span class="name">end</span> <span class="op">-</span> <span class="number">1</span><span class="op">)</span><span class="op">)</span><br />
+<a class="lnum" href="#149" name="149">0149</a>        <span class="name">end</span> <span class="op">=</span> <span class="name">_w</span><span class="op">(</span><span class="name">s</span><span class="op">,</span> <span class="name">end</span><span class="op">)</span><span class="op">.</span><span class="name">end</span><span class="op">(</span><span class="op">)</span><br />
+<a class="lnum" href="#150" name="150">0150</a>        <span class="name">nextchar</span> <span class="op">=</span> <span class="name">s</span><span class="op">[</span><span class="name">end</span><span class="op">:</span><span class="name">end</span> <span class="op">+</span> <span class="number">1</span><span class="op">]</span><br />
+<a class="lnum" href="#151" name="151">0151</a>        <span class="name">end</span> <span class="op">+=</span> <span class="number">1</span><br />
+<a class="lnum" href="#152" name="152">0152</a>        <span class="keyword">if</span> <span class="name">nextchar</span> <span class="op">!=</span> <span class="string">'"'</span><span class="op">:</span><br />
+<a class="lnum" href="#153" name="153">0153</a>            <span class="keyword">raise</span> <span class="name">ValueError</span><span class="op">(</span><span class="name">errmsg</span><span class="op">(</span><span class="string">"Expecting property name"</span><span class="op">,</span> <span class="name">s</span><span class="op">,</span> <span class="name">end</span> <span class="op">-</span> <span class="number">1</span><span class="op">)</span><span class="op">)</span><br />
+<a class="lnum" href="#154" name="154">0154</a>    <span class="name">object_hook</span> <span class="op">=</span> <span class="name">getattr</span><span class="op">(</span><span class="name">context</span><span class="op">,</span> <span class="string">'object_hook'</span><span class="op">,</span> <span class="name">None</span><span class="op">)</span><br />
+<a class="lnum" href="#155" name="155">0155</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="#156" name="156">0156</a>        <span class="name">pairs</span> <span class="op">=</span> <span class="name">object_hook</span><span class="op">(</span><span class="name">pairs</span><span class="op">)</span><br />
+<a class="lnum" href="#157" name="157">0157</a>    <span class="keyword">return</span> <span class="name">pairs</span><span class="op">,</span> <span class="name">end</span><br />
+<a class="lnum" href="#158" name="158">0158</a><span class="name">pattern</span><span class="op">(</span><span class="string">r'{'</span><span class="op">)</span><span class="op">(</span><span class="name">JSONObject</span><span class="op">)</span><br />
+<a class="lnum" href="#159" name="159">0159</a><br />
+<a class="lnum" href="#160" name="160">0160</a><span class="keyword">def</span> <span class="name">JSONArray</span><span class="op">(</span><span class="name">match</span><span class="op">,</span> <span class="name">context</span><span class="op">,</span> <span class="name">_w</span><span class="op">=</span><span class="name">WHITESPACE</span><span class="op">.</span><span class="name">match</span><span class="op">)</span><span class="op">:</span><br />
+<a class="lnum" href="#161" name="161">0161</a>    <span class="name">values</span> <span class="op">=</span> <span class="op">[</span><span class="op">]</span><br />
+<a class="lnum" href="#162" name="162">0162</a>    <span class="name">s</span> <span class="op">=</span> <span class="name">match</span><span class="op">.</span><span class="name">string</span><br />
+<a class="lnum" href="#163" name="163">0163</a>    <span class="name">end</span> <span class="op">=</span> <span class="name">_w</span><span class="op">(</span><span class="name">s</span><span class="op">,</span> <span class="name">match</span><span class="op">.</span><span class="name">end</span><span class="op">(</span><span class="op">)</span><span class="op">)</span><span class="op">.</span><span class="name">end</span><span class="op">(</span><span class="op">)</span><br />
+<a class="lnum" href="#164" name="164">0164</a>    <span class="comment"># look-ahead for trivial empty array</span><br />
+<a class="lnum" href="#165" name="165">0165</a><span class="comment"></span>    <span class="name">nextchar</span> <span class="op">=</span> <span class="name">s</span><span class="op">[</span><span class="name">end</span><span class="op">:</span><span class="name">end</span> <span class="op">+</span> <span class="number">1</span><span class="op">]</span><br />
+<a class="lnum" href="#166" name="166">0166</a>    <span class="keyword">if</span> <span class="name">nextchar</span> <span class="op">==</span> <span class="string">']'</span><span class="op">:</span><br />
+<a class="lnum" href="#167" name="167">0167</a>        <span class="keyword">return</span> <span class="name">values</span><span class="op">,</span> <span class="name">end</span> <span class="op">+</span> <span class="number">1</span><br />
+<a class="lnum" href="#168" name="168">0168</a>    <span class="name">iterscan</span> <span class="op">=</span> <span class="name">JSONScanner</span><span class="op">.</span><span class="name">iterscan</span><br />
+<a class="lnum" href="#169" name="169">0169</a>    <span class="keyword">while</span> <span class="name">True</span><span class="op">:</span><br />
+<a class="lnum" href="#170" name="170">0170</a>        <span class="keyword">try</span><span class="op">:</span><br />
+<a class="lnum" href="#171" name="171">0171</a>            <span class="name">value</span><span class="op">,</span> <span class="name">end</span> <span class="op">=</span> <span class="name">iterscan</span><span class="op">(</span><span class="name">s</span><span class="op">,</span> <span class="name">idx</span><span class="op">=</span><span class="name">end</span><span class="op">,</span> <span class="name">context</span><span class="op">=</span><span class="name">context</span><span class="op">)</span><span class="op">.</span><span class="name">next</span><span class="op">(</span><span class="op">)</span><br />
+<a class="lnum" href="#172" name="172">0172</a>        <span class="keyword">except</span> <span class="name">StopIteration</span><span class="op">:</span><br />
+<a class="lnum" href="#173" name="173">0173</a>            <span class="keyword">raise</span> <span class="name">ValueError</span><span class="op">(</span><span class="name">errmsg</span><span class="op">(</span><span class="string">"Expecting object"</span><span class="op">,</span> <span class="name">s</span><span class="op">,</span> <span class="name">end</span><span class="op">)</span><span class="op">)</span><br />
+<a class="lnum" href="#174" name="174">0174</a>        <span class="name">values</span><span class="op">.</span><span class="name">append</span><span class="op">(</span><span class="name">value</span><span class="op">)</span><br />
+<a class="lnum" href="#175" name="175">0175</a>        <span class="name">end</span> <span class="op">=</span> <span class="name">_w</span><span class="op">(</span><span class="name">s</span><span class="op">,</span> <span class="name">end</span><span class="op">)</span><span class="op">.</span><span class="name">end</span><span class="op">(</span><span class="op">)</span><br />
+<a class="lnum" href="#176" name="176">0176</a>        <span class="name">nextchar</span> <span class="op">=</span> <span class="name">s</span><span class="op">[</span><span class="name">end</span><span class="op">:</span><span class="name">end</span> <span class="op">+</span> <span class="number">1</span><span class="op">]</span><br />
+<a class="lnum" href="#177" name="177">0177</a>        <span class="name">end</span> <span class="op">+=</span> <span class="number">1</span><br />
+<a class="lnum" href="#178" name="178">0178</a>        <span class="keyword">if</span> <span class="name">nextchar</span> <span class="op">==</span> <span class="string">']'</span><span class="op">:</span><br />
+<a class="lnum" href="#179" name="179">0179</a>            <span class="keyword">break</span><br />
+<a class="lnum" href="#180" name="180">0180</a>        <span class="keyword">if</span> <span class="name">nextchar</span> <span class="op">!=</span> <span class="string">','</span><span class="op">:</span><br />
+<a class="lnum" href="#181" name="181">0181</a>            <span class="keyword">raise</span> <span class="name">ValueError</span><span class="op">(</span><span class="name">errmsg</span><span class="op">(</span><span class="string">"Expecting , delimiter"</span><span class="op">,</span> <span class="name">s</span><span class="op">,</span> <span class="name">end</span><span class="op">)</span><span class="op">)</span><br />
+<a class="lnum" href="#182" name="182">0182</a>        <span class="name">end</span> <span class="op">=</span> <span class="name">_w</span><span class="op">(</span><span class="name">s</span><span class="op">,</span> <span class="name">end</span><span class="op">)</span><span class="op">.</span><span class="name">end</span><span class="op">(</span><span class="op">)</span><br />
+<a class="lnum" href="#183" name="183">0183</a>    <span class="keyword">return</span> <span class="name">values</span><span class="op">,</span> <span class="name">end</span><br />
+<a class="lnum" href="#184" name="184">0184</a><span class="name">pattern</span><span class="op">(</span><span class="string">r'\['</span><span class="op">)</span><span class="op">(</span><span class="name">JSONArray</span><span class="op">)</span><br />
+<a class="lnum" href="#185" name="185">0185</a><br />
+<a class="lnum" href="#186" name="186">0186</a><span class="name">ANYTHING</span> <span class="op">=</span> <span class="op">[</span><br />
+<a class="lnum" href="#187" name="187">0187</a>    <span class="name">JSONObject</span><span class="op">,</span><br />
+<a class="lnum" href="#188" name="188">0188</a>    <span class="name">JSONArray</span><span class="op">,</span><br />
+<a class="lnum" href="#189" name="189">0189</a>    <span class="name">JSONString</span><span class="op">,</span><br />
+<a class="lnum" href="#190" name="190">0190</a>    <span class="name">JSONConstant</span><span class="op">,</span><br />
+<a class="lnum" href="#191" name="191">0191</a>    <span class="name">JSONNumber</span><span class="op">,</span><br />
+<a class="lnum" href="#192" name="192">0192</a><span class="op">]</span><br />
+<a class="lnum" href="#193" name="193">0193</a><br />
+<a class="lnum" href="#194" name="194">0194</a><span class="name">JSONScanner</span> <span class="op">=</span> <span class="name">Scanner</span><span class="op">(</span><span class="name">ANYTHING</span><span class="op">)</span><br />
+<a class="lnum" href="#195" name="195">0195</a><br />
+<a class="lnum" href="#196" name="196">0196</a><span class="keyword">class</span> <span class="name">JSONDecoder</span><span class="op">(</span><span class="name">object</span><span class="op">)</span><span class="op">:</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">    Simple JSON <http://json.org> decoder</span><br />
+<a class="lnum" href="#199" name="199">0199</a><span class="string"></span><br />
+<a class="lnum" href="#200" name="200">0200</a><span class="string">    Performs the following translations in decoding:</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">    +---------------+-------------------+</span><br />
+<a class="lnum" href="#203" name="203">0203</a><span class="string">    | JSON          | Python            |</span><br />
+<a class="lnum" href="#204" name="204">0204</a><span class="string">    +===============+===================+</span><br />
+<a class="lnum" href="#205" name="205">0205</a><span class="string">    | object        | dict              |</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">    | array         | list              |</span><br />
+<a class="lnum" href="#208" name="208">0208</a><span class="string">    +---------------+-------------------+</span><br />
+<a class="lnum" href="#209" name="209">0209</a><span class="string">    | string        | unicode           |</span><br />
+<a class="lnum" href="#210" name="210">0210</a><span class="string">    +---------------+-------------------+</span><br />
+<a class="lnum" href="#211" name="211">0211</a><span class="string">    | number (int)  | int, long         |</span><br />
+<a class="lnum" href="#212" name="212">0212</a><span class="string">    +---------------+-------------------+</span><br />
+<a class="lnum" href="#213" name="213">0213</a><span class="string">    | number (real) | float             |</span><br />
+<a class="lnum" href="#214" name="214">0214</a><span class="string">    +---------------+-------------------+</span><br />
+<a class="lnum" href="#215" name="215">0215</a><span class="string">    | true          | True              |</span><br />
+<a class="lnum" href="#216" name="216">0216</a><span class="string">    +---------------+-------------------+</span><br />
+<a class="lnum" href="#217" name="217">0217</a><span class="string">    | false         | False             |</span><br />
+<a class="lnum" href="#218" name="218">0218</a><span class="string">    +---------------+-------------------+</span><br />
+<a class="lnum" href="#219" name="219">0219</a><span class="string">    | null          | None              |</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"></span><br />
+<a class="lnum" href="#222" name="222">0222</a><span class="string">    It also understands ``NaN``, ``Infinity``, and ``-Infinity`` as</span><br />
+<a class="lnum" href="#223" name="223">0223</a><span class="string">    their corresponding ``float`` values, which is outside the JSON spec.</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><br />
+<a class="lnum" href="#226" name="226">0226</a>    <span class="name">_scanner</span> <span class="op">=</span> <span class="name">Scanner</span><span class="op">(</span><span class="name">ANYTHING</span><span class="op">)</span><br />
+<a class="lnum" href="#227" name="227">0227</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">'decode'</span><span class="op">,</span> <span class="string">'raw_decode'</span><span class="op">]</span><br />
+<a class="lnum" href="#228" name="228">0228</a><br />
+<a class="lnum" href="#229" name="229">0229</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">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><span class="op">:</span><br />
+<a class="lnum" href="#230" name="230">0230</a>        <span class="string">"""</span><br />
+<a class="lnum" href="#231" name="231">0231</a><span class="string">        ``encoding`` determines the encoding used to interpret any ``str``</span><br />
+<a class="lnum" href="#232" name="232">0232</a><span class="string">        objects decoded by this instance (utf-8 by default).  It has no</span><br />
+<a class="lnum" href="#233" name="233">0233</a><span class="string">        effect when decoding ``unicode`` objects.</span><br />
+<a class="lnum" href="#234" name="234">0234</a><span class="string">        </span><br />
+<a class="lnum" href="#235" name="235">0235</a><span class="string">        Note that currently only encodings that are a superset of ASCII work,</span><br />
+<a class="lnum" href="#236" name="236">0236</a><span class="string">        strings of other encodings should be passed in as ``unicode``.</span><br />
+<a class="lnum" href="#237" name="237">0237</a><span class="string"></span><br />
+<a class="lnum" href="#238" name="238">0238</a><span class="string">        ``object_hook``, if specified, will be called with the result</span><br />
+<a class="lnum" href="#239" name="239">0239</a><span class="string">        of every JSON object decoded and its return value will be used in</span><br />
+<a class="lnum" href="#240" name="240">0240</a><span class="string">        place of the given ``dict``.  This can be used to provide custom</span><br />
+<a class="lnum" href="#241" name="241">0241</a><span class="string">        deserializations (e.g. to support JSON-RPC class hinting).</span><br />
+<a class="lnum" href="#242" name="242">0242</a><span class="string">        """</span><br />
+<a class="lnum" href="#243" name="243">0243</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="#244" name="244">0244</a>        <span class="name">self</span><span class="op">.</span><span class="name">object_hook</span> <span class="op">=</span> <span class="name">object_hook</span><br />
+<a class="lnum" href="#245" name="245">0245</a><br />
+<a class="lnum" href="#246" name="246">0246</a>    <span class="keyword">def</span> <span class="name">decode</span><span class="op">(</span><span class="name">self</span><span class="op">,</span> <span class="name">s</span><span class="op">,</span> <span class="name">_w</span><span class="op">=</span><span class="name">WHITESPACE</span><span class="op">.</span><span class="name">match</span><span class="op">)</span><span class="op">:</span><br />
+<a class="lnum" href="#247" name="247">0247</a>        <span class="string">"""</span><br />
+<a class="lnum" href="#248" name="248">0248</a><span class="string">        Return the Python representation of ``s`` (a ``str`` or ``unicode``</span><br />
+<a class="lnum" href="#249" name="249">0249</a><span class="string">        instance containing a JSON document)</span><br />
+<a class="lnum" href="#250" name="250">0250</a><span class="string">        """</span><br />
+<a class="lnum" href="#251" name="251">0251</a>        <span class="name">obj</span><span class="op">,</span> <span class="name">end</span> <span class="op">=</span> <span class="name">self</span><span class="op">.</span><span class="name">raw_decode</span><span class="op">(</span><span class="name">s</span><span class="op">,</span> <span class="name">idx</span><span class="op">=</span><span class="name">_w</span><span class="op">(</span><span class="name">s</span><span class="op">,</span> <span class="number">0</span><span class="op">)</span><span class="op">.</span><span class="name">end</span><span class="op">(</span><span class="op">)</span><span class="op">)</span><br />
+<a class="lnum" href="#252" name="252">0252</a>        <span class="name">end</span> <span class="op">=</span> <span class="name">_w</span><span class="op">(</span><span class="name">s</span><span class="op">,</span> <span class="name">end</span><span class="op">)</span><span class="op">.</span><span class="name">end</span><span class="op">(</span><span class="op">)</span><br />
+<a class="lnum" href="#253" name="253">0253</a>        <span class="keyword">if</span> <span class="name">end</span> <span class="op">!=</span> <span class="name">len</span><span class="op">(</span><span class="name">s</span><span class="op">)</span><span class="op">:</span><br />
+<a class="lnum" href="#254" name="254">0254</a>            <span class="keyword">raise</span> <span class="name">ValueError</span><span class="op">(</span><span class="name">errmsg</span><span class="op">(</span><span class="string">"Extra data"</span><span class="op">,</span> <span class="name">s</span><span class="op">,</span> <span class="name">end</span><span class="op">,</span> <span class="name">len</span><span class="op">(</span><span class="name">s</span><span class="op">)</span><span class="op">)</span><span class="op">)</span><br />
+<a class="lnum" href="#255" name="255">0255</a>        <span class="keyword">return</span> <span class="name">obj</span><br />
+<a class="lnum" href="#256" name="256">0256</a><br />
+<a class="lnum" href="#257" name="257">0257</a>    <span class="keyword">def</span> <span class="name">raw_decode</span><span class="op">(</span><span class="name">self</span><span class="op">,</span> <span class="name">s</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="#258" name="258">0258</a>        <span class="string">"""</span><br />
+<a class="lnum" href="#259" name="259">0259</a><span class="string">        Decode a JSON document from ``s`` (a ``str`` or ``unicode`` beginning</span><br />
+<a class="lnum" href="#260" name="260">0260</a><span class="string">        with a JSON document) and return a 2-tuple of the Python</span><br />
+<a class="lnum" href="#261" name="261">0261</a><span class="string">        representation and the index in ``s`` where the document ended.</span><br />
+<a class="lnum" href="#262" name="262">0262</a><span class="string"></span><br />
+<a class="lnum" href="#263" name="263">0263</a><span class="string">        This can be used to decode a JSON document from a string that may</span><br />
+<a class="lnum" href="#264" name="264">0264</a><span class="string">        have extraneous data at the end.</span><br />
+<a class="lnum" href="#265" name="265">0265</a><span class="string">        """</span><br />
+<a class="lnum" href="#266" name="266">0266</a>        <span class="name">kw</span><span class="op">.</span><span class="name">setdefault</span><span class="op">(</span><span class="string">'context'</span><span class="op">,</span> <span class="name">self</span><span class="op">)</span><br />
+<a class="lnum" href="#267" name="267">0267</a>        <span class="keyword">try</span><span class="op">:</span><br />
+<a class="lnum" href="#268" name="268">0268</a>            <span class="name">obj</span><span class="op">,</span> <span class="name">end</span> <span class="op">=</span> <span class="name">self</span><span class="op">.</span><span class="name">_scanner</span><span class="op">.</span><span class="name">iterscan</span><span class="op">(</span><span class="name">s</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">next</span><span class="op">(</span><span class="op">)</span><br />
+<a class="lnum" href="#269" name="269">0269</a>        <span class="keyword">except</span> <span class="name">StopIteration</span><span class="op">:</span><br />
+<a class="lnum" href="#270" name="270">0270</a>            <span class="keyword">raise</span> <span class="name">ValueError</span><span class="op">(</span><span class="string">"No JSON object could be decoded"</span><span class="op">)</span><br />
+<a class="lnum" href="#271" name="271">0271</a>        <span class="keyword">return</span> <span class="name">obj</span><span class="op">,</span> <span class="name">end</span><br />
+<a class="lnum" href="#272" name="272">0272</a><br />
+<a class="lnum" href="#273" name="273">0273</a><span class="name">__all__</span> <span class="op">=</span> <span class="op">[</span><span class="string">'JSONDecoder'</span><span class="op">]</span></code></div></body></html>
\ No newline at end of file
--- /dev/null
+<html><head><title>/Users/bob/src/simplejson/simplejson/encoder.py</title>
+ <script type="text/javascript"><!--
+
+function show_line_range() {
+ var href = document.location.href;
+ if (href.indexOf('?') == -1) {
+ return;
+ }
+ var qs = href.substring(href.indexOf('?')+1);
+ if (qs.indexOf('#') >= 0) {
+ qs = qs.substring(0, qs.indexOf('#'));
+ }
+ var first = qs.match(/f=(\d+)/)[1];
+ var last = qs.match(/l=(\d+)/)[1];
+ if (! first || ! last) {
+ return;
+ }
+ var anchors = document.getElementsByTagName('A');
+ var container = document.createElement('DIV');
+ container.className = 'highlighted';
+ var children = [];
+ var start = null;
+ var parent = null;
+ var highlight = false;
+ for (var i = 0; i < anchors.length; i++) {
+ var el = anchors[i];
+ if (el.getAttribute('name') == first) {
+ start = el.previousSibling;
+ parent = el.parentNode;
+ highlight = true;
+ }
+ if (el.getAttribute('name') == last) {
+ break;
+ }
+ if (highlight) {
+ children[children.length] = el;
+ el = el.nextSibling;
+ while (el && el.tagName != 'A') {
+ children[children.length] = el;
+ el = el.nextSibling;
+ }
+ }
+ }
+ for (i=0; i<children.length; i++) {
+ container.appendChild(children[i]);
+ }
+ if (start) {
+ start.parentNode.insertBefore(container, start.nextSibling);
+ } else {
+ parent.insertBefore(container, parent.childNodes[0]);
+ }
+}
+
+ // --></script>
+ <style>
+ div.python {
+ color: #333
+ }
+ div.python a.lnum {
+ color: #555;
+ background-color: #eee;
+ border-right: 1px solid #999;
+ padding-right: 2px;
+ margin-right: 4px;
+ }
+ div.python span.comment { color: #933 }
+ div.python span.keyword { color: #a3e; font-weight: bold }
+ div.python span.op { color: #c96 }
+ div.python span.string { color: #6a6 }
+ div.python span.name { }
+ div.python span.text { color: #333 }
+ div.highlighted { background-color: #ff9; border: 1px solid #009 }
+ </style></head><body onload="show_line_range()"><div class="python"><code><a class="lnum" href="#1" name="1">0001</a><span class="string">"""</span><br />
+<a class="lnum" href="#2" name="2">0002</a><span class="string">Implementation of JSONEncoder</span><br />
+<a class="lnum" href="#3" name="3">0003</a><span class="string">"""</span><br />
+<a class="lnum" href="#4" name="4">0004</a><span class="keyword">import</span> <span class="name">re</span><br />
+<a class="lnum" href="#5" name="5">0005</a><span class="keyword">try</span><span class="op">:</span><br />
+<a class="lnum" href="#6" name="6">0006</a>    <span class="keyword">from</span> <span class="name">simplejson</span> <span class="keyword">import</span> <span class="name">_speedups</span><br />
+<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="#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="#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
--- /dev/null
+<html><head><title>/Users/bob/src/simplejson/simplejson/jsonfilter.py</title>
+ <script type="text/javascript"><!--
+
+function show_line_range() {
+ var href = document.location.href;
+ if (href.indexOf('?') == -1) {
+ return;
+ }
+ var qs = href.substring(href.indexOf('?')+1);
+ if (qs.indexOf('#') >= 0) {
+ qs = qs.substring(0, qs.indexOf('#'));
+ }
+ var first = qs.match(/f=(\d+)/)[1];
+ var last = qs.match(/l=(\d+)/)[1];
+ if (! first || ! last) {
+ return;
+ }
+ var anchors = document.getElementsByTagName('A');
+ var container = document.createElement('DIV');
+ container.className = 'highlighted';
+ var children = [];
+ var start = null;
+ var parent = null;
+ var highlight = false;
+ for (var i = 0; i < anchors.length; i++) {
+ var el = anchors[i];
+ if (el.getAttribute('name') == first) {
+ start = el.previousSibling;
+ parent = el.parentNode;
+ highlight = true;
+ }
+ if (el.getAttribute('name') == last) {
+ break;
+ }
+ if (highlight) {
+ children[children.length] = el;
+ el = el.nextSibling;
+ while (el && el.tagName != 'A') {
+ children[children.length] = el;
+ el = el.nextSibling;
+ }
+ }
+ }
+ for (i=0; i<children.length; i++) {
+ container.appendChild(children[i]);
+ }
+ if (start) {
+ start.parentNode.insertBefore(container, start.nextSibling);
+ } else {
+ parent.insertBefore(container, parent.childNodes[0]);
+ }
+}
+
+ // --></script>
+ <style>
+ div.python {
+ color: #333
+ }
+ div.python a.lnum {
+ color: #555;
+ background-color: #eee;
+ border-right: 1px solid #999;
+ padding-right: 2px;
+ margin-right: 4px;
+ }
+ div.python span.comment { color: #933 }
+ div.python span.keyword { color: #a3e; font-weight: bold }
+ div.python span.op { color: #c96 }
+ div.python span.string { color: #6a6 }
+ div.python span.name { }
+ div.python span.text { color: #333 }
+ div.highlighted { background-color: #ff9; border: 1px solid #009 }
+ </style></head><body onload="show_line_range()"><div class="python"><code><a class="lnum" href="#1" name="1">0001</a><span class="keyword">import</span> <span class="name">simplejson</span><br />
+<a class="lnum" href="#2" name="2">0002</a><span class="keyword">import</span> <span class="name">cgi</span><br />
+<a class="lnum" href="#3" name="3">0003</a><br />
+<a class="lnum" href="#4" name="4">0004</a><span class="keyword">class</span> <span class="name">JSONFilter</span><span class="op">(</span><span class="name">object</span><span class="op">)</span><span class="op">:</span><br />
+<a class="lnum" href="#5" name="5">0005</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">app</span><span class="op">,</span> <span class="name">mime_type</span><span class="op">=</span><span class="string">'text/x-json'</span><span class="op">)</span><span class="op">:</span><br />
+<a class="lnum" href="#6" name="6">0006</a>        <span class="name">self</span><span class="op">.</span><span class="name">app</span> <span class="op">=</span> <span class="name">app</span><br />
+<a class="lnum" href="#7" name="7">0007</a>        <span class="name">self</span><span class="op">.</span><span class="name">mime_type</span> <span class="op">=</span> <span class="name">mime_type</span><br />
+<a class="lnum" href="#8" name="8">0008</a><br />
+<a class="lnum" href="#9" name="9">0009</a>    <span class="keyword">def</span> <span class="name">__call__</span><span class="op">(</span><span class="name">self</span><span class="op">,</span> <span class="name">environ</span><span class="op">,</span> <span class="name">start_response</span><span class="op">)</span><span class="op">:</span><br />
+<a class="lnum" href="#10" name="10">0010</a>        <span class="comment"># Read JSON POST input to jsonfilter.json if matching mime type</span><br />
+<a class="lnum" href="#11" name="11">0011</a><span class="comment"></span>        <span class="name">response</span> <span class="op">=</span> <span class="op">{</span><span class="string">'status'</span><span class="op">:</span> <span class="string">'200 OK'</span><span class="op">,</span> <span class="string">'headers'</span><span class="op">:</span> <span class="op">[</span><span class="op">]</span><span class="op">}</span><br />
+<a class="lnum" href="#12" name="12">0012</a>        <span class="keyword">def</span> <span class="name">json_start_response</span><span class="op">(</span><span class="name">status</span><span class="op">,</span> <span class="name">headers</span><span class="op">)</span><span class="op">:</span><br />
+<a class="lnum" href="#13" name="13">0013</a>            <span class="name">response</span><span class="op">[</span><span class="string">'status'</span><span class="op">]</span> <span class="op">=</span> <span class="name">status</span><br />
+<a class="lnum" href="#14" name="14">0014</a>            <span class="name">response</span><span class="op">[</span><span class="string">'headers'</span><span class="op">]</span><span class="op">.</span><span class="name">extend</span><span class="op">(</span><span class="name">headers</span><span class="op">)</span><br />
+<a class="lnum" href="#15" name="15">0015</a>        <span class="name">environ</span><span class="op">[</span><span class="string">'jsonfilter.mime_type'</span><span class="op">]</span> <span class="op">=</span> <span class="name">self</span><span class="op">.</span><span class="name">mime_type</span><br />
+<a class="lnum" href="#16" name="16">0016</a>        <span class="keyword">if</span> <span class="name">environ</span><span class="op">.</span><span class="name">get</span><span class="op">(</span><span class="string">'REQUEST_METHOD'</span><span class="op">,</span> <span class="string">''</span><span class="op">)</span> <span class="op">==</span> <span class="string">'POST'</span><span class="op">:</span><br />
+<a class="lnum" href="#17" name="17">0017</a>            <span class="keyword">if</span> <span class="name">environ</span><span class="op">.</span><span class="name">get</span><span class="op">(</span><span class="string">'CONTENT_TYPE'</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">mime_type</span><span class="op">:</span><br />
+<a class="lnum" href="#18" name="18">0018</a>                <span class="name">args</span> <span class="op">=</span> <span class="op">[</span><span class="name">_</span> <span class="keyword">for</span> <span class="name">_</span> <span class="keyword">in</span> <span class="op">[</span><span class="name">environ</span><span class="op">.</span><span class="name">get</span><span class="op">(</span><span class="string">'CONTENT_LENGTH'</span><span class="op">)</span><span class="op">]</span> <span class="keyword">if</span> <span class="name">_</span><span class="op">]</span><br />
+<a class="lnum" href="#19" name="19">0019</a>                <span class="name">data</span> <span class="op">=</span> <span class="name">environ</span><span class="op">[</span><span class="string">'wsgi.input'</span><span class="op">]</span><span class="op">.</span><span class="name">read</span><span class="op">(</span><span class="op">*</span><span class="name">map</span><span class="op">(</span><span class="name">int</span><span class="op">,</span> <span class="name">args</span><span class="op">)</span><span class="op">)</span><br />
+<a class="lnum" href="#20" name="20">0020</a>                <span class="name">environ</span><span class="op">[</span><span class="string">'jsonfilter.json'</span><span class="op">]</span> <span class="op">=</span> <span class="name">simplejson</span><span class="op">.</span><span class="name">loads</span><span class="op">(</span><span class="name">data</span><span class="op">)</span><br />
+<a class="lnum" href="#21" name="21">0021</a>        <span class="name">res</span> <span class="op">=</span> <span class="name">simplejson</span><span class="op">.</span><span class="name">dumps</span><span class="op">(</span><span class="name">self</span><span class="op">.</span><span class="name">app</span><span class="op">(</span><span class="name">environ</span><span class="op">,</span> <span class="name">json_start_response</span><span class="op">)</span><span class="op">)</span><br />
+<a class="lnum" href="#22" name="22">0022</a>        <span class="name">jsonp</span> <span class="op">=</span> <span class="name">cgi</span><span class="op">.</span><span class="name">parse_qs</span><span class="op">(</span><span class="name">environ</span><span class="op">.</span><span class="name">get</span><span class="op">(</span><span class="string">'QUERY_STRING'</span><span class="op">,</span> <span class="string">''</span><span class="op">)</span><span class="op">)</span><span class="op">.</span><span class="name">get</span><span class="op">(</span><span class="string">'jsonp'</span><span class="op">)</span><br />
+<a class="lnum" href="#23" name="23">0023</a>        <span class="keyword">if</span> <span class="name">jsonp</span><span class="op">:</span><br />
+<a class="lnum" href="#24" name="24">0024</a>            <span class="name">content_type</span> <span class="op">=</span> <span class="string">'text/javascript'</span><br />
+<a class="lnum" href="#25" name="25">0025</a>            <span class="name">res</span> <span class="op">=</span> <span class="string">''</span><span class="op">.</span><span class="name">join</span><span class="op">(</span><span class="name">jsonp</span> <span class="op">+</span> <span class="op">[</span><span class="string">'('</span><span class="op">,</span> <span class="name">res</span><span class="op">,</span> <span class="string">')'</span><span class="op">]</span><span class="op">)</span><br />
+<a class="lnum" href="#26" name="26">0026</a>        <span class="keyword">elif</span> <span class="string">'Opera'</span> <span class="keyword">in</span> <span class="name">environ</span><span class="op">.</span><span class="name">get</span><span class="op">(</span><span class="string">'HTTP_USER_AGENT'</span><span class="op">,</span> <span class="string">''</span><span class="op">)</span><span class="op">:</span><br />
+<a class="lnum" href="#27" name="27">0027</a>            <span class="comment"># Opera has bunk XMLHttpRequest support for most mime types</span><br />
+<a class="lnum" href="#28" name="28">0028</a><span class="comment"></span>            <span class="name">content_type</span> <span class="op">=</span> <span class="string">'text/plain'</span><br />
+<a class="lnum" href="#29" name="29">0029</a>        <span class="keyword">else</span><span class="op">:</span><br />
+<a class="lnum" href="#30" name="30">0030</a>            <span class="name">content_type</span> <span class="op">=</span> <span class="name">self</span><span class="op">.</span><span class="name">mime_type</span><br />
+<a class="lnum" href="#31" name="31">0031</a>        <span class="name">headers</span> <span class="op">=</span> <span class="op">[</span><br />
+<a class="lnum" href="#32" name="32">0032</a>            <span class="op">(</span><span class="string">'Content-type'</span><span class="op">,</span> <span class="name">content_type</span><span class="op">)</span><span class="op">,</span><br />
+<a class="lnum" href="#33" name="33">0033</a>            <span class="op">(</span><span class="string">'Content-length'</span><span class="op">,</span> <span class="name">len</span><span class="op">(</span><span class="name">res</span><span class="op">)</span><span class="op">)</span><span class="op">,</span><br />
+<a class="lnum" href="#34" name="34">0034</a>        <span class="op">]</span><br />
+<a class="lnum" href="#35" name="35">0035</a>        <span class="name">headers</span><span class="op">.</span><span class="name">extend</span><span class="op">(</span><span class="name">response</span><span class="op">[</span><span class="string">'headers'</span><span class="op">]</span><span class="op">)</span><br />
+<a class="lnum" href="#36" name="36">0036</a>        <span class="name">start_response</span><span class="op">(</span><span class="name">response</span><span class="op">[</span><span class="string">'status'</span><span class="op">]</span><span class="op">,</span> <span class="name">headers</span><span class="op">)</span><br />
+<a class="lnum" href="#37" name="37">0037</a>        <span class="keyword">return</span> <span class="op">[</span><span class="name">res</span><span class="op">]</span><br />
+<a class="lnum" href="#38" name="38">0038</a><br />
+<a class="lnum" href="#39" name="39">0039</a><span class="keyword">def</span> <span class="name">factory</span><span class="op">(</span><span class="name">app</span><span class="op">,</span> <span class="name">global_conf</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="#40" name="40">0040</a>    <span class="keyword">return</span> <span class="name">JSONFilter</span><span class="op">(</span><span class="name">app</span><span class="op">,</span> <span class="op">**</span><span class="name">kw</span><span class="op">)</span></code></div></body></html>
\ No newline at end of file
--- /dev/null
+<html><head><title>/Users/bob/src/simplejson/simplejson/scanner.py</title>
+ <script type="text/javascript"><!--
+
+function show_line_range() {
+ var href = document.location.href;
+ if (href.indexOf('?') == -1) {
+ return;
+ }
+ var qs = href.substring(href.indexOf('?')+1);
+ if (qs.indexOf('#') >= 0) {
+ qs = qs.substring(0, qs.indexOf('#'));
+ }
+ var first = qs.match(/f=(\d+)/)[1];
+ var last = qs.match(/l=(\d+)/)[1];
+ if (! first || ! last) {
+ return;
+ }
+ var anchors = document.getElementsByTagName('A');
+ var container = document.createElement('DIV');
+ container.className = 'highlighted';
+ var children = [];
+ var start = null;
+ var parent = null;
+ var highlight = false;
+ for (var i = 0; i < anchors.length; i++) {
+ var el = anchors[i];
+ if (el.getAttribute('name') == first) {
+ start = el.previousSibling;
+ parent = el.parentNode;
+ highlight = true;
+ }
+ if (el.getAttribute('name') == last) {
+ break;
+ }
+ if (highlight) {
+ children[children.length] = el;
+ el = el.nextSibling;
+ while (el && el.tagName != 'A') {
+ children[children.length] = el;
+ el = el.nextSibling;
+ }
+ }
+ }
+ for (i=0; i<children.length; i++) {
+ container.appendChild(children[i]);
+ }
+ if (start) {
+ start.parentNode.insertBefore(container, start.nextSibling);
+ } else {
+ parent.insertBefore(container, parent.childNodes[0]);
+ }
+}
+
+ // --></script>
+ <style>
+ div.python {
+ color: #333
+ }
+ div.python a.lnum {
+ color: #555;
+ background-color: #eee;
+ border-right: 1px solid #999;
+ padding-right: 2px;
+ margin-right: 4px;
+ }
+ div.python span.comment { color: #933 }
+ div.python span.keyword { color: #a3e; font-weight: bold }
+ div.python span.op { color: #c96 }
+ div.python span.string { color: #6a6 }
+ div.python span.name { }
+ div.python span.text { color: #333 }
+ div.highlighted { background-color: #ff9; border: 1px solid #009 }
+ </style></head><body onload="show_line_range()"><div class="python"><code><a class="lnum" href="#1" name="1">0001</a><span class="string">"""</span><br />
+<a class="lnum" href="#2" name="2">0002</a><span class="string">Iterator based sre token scanner</span><br />
+<a class="lnum" href="#3" name="3">0003</a><span class="string">"""</span><br />
+<a class="lnum" href="#4" name="4">0004</a><span class="keyword">import</span> <span class="name">sre_parse</span><span class="op">,</span> <span class="name">sre_compile</span><span class="op">,</span> <span class="name">sre_constants</span><br />
+<a class="lnum" href="#5" name="5">0005</a><span class="keyword">from</span> <span class="name">sre_constants</span> <span class="keyword">import</span> <span class="name">BRANCH</span><span class="op">,</span> <span class="name">SUBPATTERN</span><br />
+<a class="lnum" href="#6" name="6">0006</a><span class="keyword">from</span> <span class="name">re</span> <span class="keyword">import</span> <span class="name">VERBOSE</span><span class="op">,</span> <span class="name">MULTILINE</span><span class="op">,</span> <span class="name">DOTALL</span><br />
+<a class="lnum" href="#7" name="7">0007</a><span class="keyword">import</span> <span class="name">re</span><br />
+<a class="lnum" href="#8" name="8">0008</a><br />
+<a class="lnum" href="#9" name="9">0009</a><span class="name">__all__</span> <span class="op">=</span> <span class="op">[</span><span class="string">'Scanner'</span><span class="op">,</span> <span class="string">'pattern'</span><span class="op">]</span><br />
+<a class="lnum" href="#10" name="10">0010</a><br />
+<a class="lnum" href="#11" name="11">0011</a><span class="name">FLAGS</span> <span class="op">=</span> <span class="op">(</span><span class="name">VERBOSE</span> <span class="op">|</span> <span class="name">MULTILINE</span> <span class="op">|</span> <span class="name">DOTALL</span><span class="op">)</span><br />
+<a class="lnum" href="#12" name="12">0012</a><span class="keyword">class</span> <span class="name">Scanner</span><span class="op">(</span><span class="name">object</span><span class="op">)</span><span class="op">:</span><br />
+<a class="lnum" href="#13" name="13">0013</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">lexicon</span><span class="op">,</span> <span class="name">flags</span><span class="op">=</span><span class="name">FLAGS</span><span class="op">)</span><span class="op">:</span><br />
+<a class="lnum" href="#14" name="14">0014</a>        <span class="name">self</span><span class="op">.</span><span class="name">actions</span> <span class="op">=</span> <span class="op">[</span><span class="name">None</span><span class="op">]</span><br />
+<a class="lnum" href="#15" name="15">0015</a>        <span class="comment"># combine phrases into a compound pattern</span><br />
+<a class="lnum" href="#16" name="16">0016</a><span class="comment"></span>        <span class="name">s</span> <span class="op">=</span> <span class="name">sre_parse</span><span class="op">.</span><span class="name">Pattern</span><span class="op">(</span><span class="op">)</span><br />
+<a class="lnum" href="#17" name="17">0017</a>        <span class="name">s</span><span class="op">.</span><span class="name">flags</span> <span class="op">=</span> <span class="name">flags</span><br />
+<a class="lnum" href="#18" name="18">0018</a>        <span class="name">p</span> <span class="op">=</span> <span class="op">[</span><span class="op">]</span><br />
+<a class="lnum" href="#19" name="19">0019</a>        <span class="keyword">for</span> <span class="name">idx</span><span class="op">,</span> <span class="name">token</span> <span class="keyword">in</span> <span class="name">enumerate</span><span class="op">(</span><span class="name">lexicon</span><span class="op">)</span><span class="op">:</span><br />
+<a class="lnum" href="#20" name="20">0020</a>            <span class="name">phrase</span> <span class="op">=</span> <span class="name">token</span><span class="op">.</span><span class="name">pattern</span><br />
+<a class="lnum" href="#21" name="21">0021</a>            <span class="keyword">try</span><span class="op">:</span><br />
+<a class="lnum" href="#22" name="22">0022</a>                <span class="name">subpattern</span> <span class="op">=</span> <span class="name">sre_parse</span><span class="op">.</span><span class="name">SubPattern</span><span class="op">(</span><span class="name">s</span><span class="op">,</span><br />
+<a class="lnum" href="#23" name="23">0023</a>                    <span class="op">[</span><span class="op">(</span><span class="name">SUBPATTERN</span><span class="op">,</span> <span class="op">(</span><span class="name">idx</span> <span class="op">+</span> <span class="number">1</span><span class="op">,</span> <span class="name">sre_parse</span><span class="op">.</span><span class="name">parse</span><span class="op">(</span><span class="name">phrase</span><span class="op">,</span> <span class="name">flags</span><span class="op">)</span><span class="op">)</span><span class="op">)</span><span class="op">]</span><span class="op">)</span><br />
+<a class="lnum" href="#24" name="24">0024</a>            <span class="keyword">except</span> <span class="name">sre_constants</span><span class="op">.</span><span class="name">error</span><span class="op">:</span><br />
+<a class="lnum" href="#25" name="25">0025</a>                <span class="keyword">raise</span><br />
+<a class="lnum" href="#26" name="26">0026</a>            <span class="name">p</span><span class="op">.</span><span class="name">append</span><span class="op">(</span><span class="name">subpattern</span><span class="op">)</span><br />
+<a class="lnum" href="#27" name="27">0027</a>            <span class="name">self</span><span class="op">.</span><span class="name">actions</span><span class="op">.</span><span class="name">append</span><span class="op">(</span><span class="name">token</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="name">p</span> <span class="op">=</span> <span class="name">sre_parse</span><span class="op">.</span><span class="name">SubPattern</span><span class="op">(</span><span class="name">s</span><span class="op">,</span> <span class="op">[</span><span class="op">(</span><span class="name">BRANCH</span><span class="op">,</span> <span class="op">(</span><span class="name">None</span><span class="op">,</span> <span class="name">p</span><span class="op">)</span><span class="op">)</span><span class="op">]</span><span class="op">)</span><br />
+<a class="lnum" href="#30" name="30">0030</a>        <span class="name">self</span><span class="op">.</span><span class="name">scanner</span> <span class="op">=</span> <span class="name">sre_compile</span><span class="op">.</span><span class="name">compile</span><span class="op">(</span><span class="name">p</span><span class="op">)</span><br />
+<a class="lnum" href="#31" name="31">0031</a><br />
+<a class="lnum" href="#32" name="32">0032</a><br />
+<a class="lnum" href="#33" name="33">0033</a>    <span class="keyword">def</span> <span class="name">iterscan</span><span class="op">(</span><span class="name">self</span><span class="op">,</span> <span class="name">string</span><span class="op">,</span> <span class="name">idx</span><span class="op">=</span><span class="number">0</span><span class="op">,</span> <span class="name">context</span><span class="op">=</span><span class="name">None</span><span class="op">)</span><span class="op">:</span><br />
+<a class="lnum" href="#34" name="34">0034</a>        <span class="string">"""</span><br />
+<a class="lnum" href="#35" name="35">0035</a><span class="string">        Yield match, end_idx for each match</span><br />
+<a class="lnum" href="#36" name="36">0036</a><span class="string">        """</span><br />
+<a class="lnum" href="#37" name="37">0037</a>        <span class="name">match</span> <span class="op">=</span> <span class="name">self</span><span class="op">.</span><span class="name">scanner</span><span class="op">.</span><span class="name">scanner</span><span class="op">(</span><span class="name">string</span><span class="op">,</span> <span class="name">idx</span><span class="op">)</span><span class="op">.</span><span class="name">match</span><br />
+<a class="lnum" href="#38" name="38">0038</a>        <span class="name">actions</span> <span class="op">=</span> <span class="name">self</span><span class="op">.</span><span class="name">actions</span><br />
+<a class="lnum" href="#39" name="39">0039</a>        <span class="name">lastend</span> <span class="op">=</span> <span class="name">idx</span><br />
+<a class="lnum" href="#40" name="40">0040</a>        <span class="name">end</span> <span class="op">=</span> <span class="name">len</span><span class="op">(</span><span class="name">string</span><span class="op">)</span><br />
+<a class="lnum" href="#41" name="41">0041</a>        <span class="keyword">while</span> <span class="name">True</span><span class="op">:</span><br />
+<a class="lnum" href="#42" name="42">0042</a>            <span class="name">m</span> <span class="op">=</span> <span class="name">match</span><span class="op">(</span><span class="op">)</span><br />
+<a class="lnum" href="#43" name="43">0043</a>            <span class="keyword">if</span> <span class="name">m</span> <span class="keyword">is</span> <span class="name">None</span><span class="op">:</span><br />
+<a class="lnum" href="#44" name="44">0044</a>                <span class="keyword">break</span><br />
+<a class="lnum" href="#45" name="45">0045</a>            <span class="name">matchbegin</span><span class="op">,</span> <span class="name">matchend</span> <span class="op">=</span> <span class="name">m</span><span class="op">.</span><span class="name">span</span><span class="op">(</span><span class="op">)</span><br />
+<a class="lnum" href="#46" name="46">0046</a>            <span class="keyword">if</span> <span class="name">lastend</span> <span class="op">==</span> <span class="name">matchend</span><span class="op">:</span><br />
+<a class="lnum" href="#47" name="47">0047</a>                <span class="keyword">break</span><br />
+<a class="lnum" href="#48" name="48">0048</a>            <span class="name">action</span> <span class="op">=</span> <span class="name">actions</span><span class="op">[</span><span class="name">m</span><span class="op">.</span><span class="name">lastindex</span><span class="op">]</span><br />
+<a class="lnum" href="#49" name="49">0049</a>            <span class="keyword">if</span> <span class="name">action</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="#50" name="50">0050</a>                <span class="name">rval</span><span class="op">,</span> <span class="name">next_pos</span> <span class="op">=</span> <span class="name">action</span><span class="op">(</span><span class="name">m</span><span class="op">,</span> <span class="name">context</span><span class="op">)</span><br />
+<a class="lnum" href="#51" name="51">0051</a>                <span class="keyword">if</span> <span class="name">next_pos</span> <span class="keyword">is</span> <span class="keyword">not</span> <span class="name">None</span> <span class="keyword">and</span> <span class="name">next_pos</span> <span class="op">!=</span> <span class="name">matchend</span><span class="op">:</span><br />
+<a class="lnum" href="#52" name="52">0052</a>                    <span class="comment"># "fast forward" the scanner</span><br />
+<a class="lnum" href="#53" name="53">0053</a><span class="comment"></span>                    <span class="name">matchend</span> <span class="op">=</span> <span class="name">next_pos</span><br />
+<a class="lnum" href="#54" name="54">0054</a>                    <span class="name">match</span> <span class="op">=</span> <span class="name">self</span><span class="op">.</span><span class="name">scanner</span><span class="op">.</span><span class="name">scanner</span><span class="op">(</span><span class="name">string</span><span class="op">,</span> <span class="name">matchend</span><span class="op">)</span><span class="op">.</span><span class="name">match</span><br />
+<a class="lnum" href="#55" name="55">0055</a>                <span class="keyword">yield</span> <span class="name">rval</span><span class="op">,</span> <span class="name">matchend</span><br />
+<a class="lnum" href="#56" name="56">0056</a>            <span class="name">lastend</span> <span class="op">=</span> <span class="name">matchend</span><br />
+<a class="lnum" href="#57" name="57">0057</a><br />
+<a class="lnum" href="#58" name="58">0058</a><span class="keyword">def</span> <span class="name">pattern</span><span class="op">(</span><span class="name">pattern</span><span class="op">,</span> <span class="name">flags</span><span class="op">=</span><span class="name">FLAGS</span><span class="op">)</span><span class="op">:</span><br />
+<a class="lnum" href="#59" name="59">0059</a>    <span class="keyword">def</span> <span class="name">decorator</span><span class="op">(</span><span class="name">fn</span><span class="op">)</span><span class="op">:</span><br />
+<a class="lnum" href="#60" name="60">0060</a>        <span class="name">fn</span><span class="op">.</span><span class="name">pattern</span> <span class="op">=</span> <span class="name">pattern</span><br />
+<a class="lnum" href="#61" name="61">0061</a>        <span class="name">fn</span><span class="op">.</span><span class="name">regex</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="name">pattern</span><span class="op">,</span> <span class="name">flags</span><span class="op">)</span><br />
+<a class="lnum" href="#62" name="62">0062</a>        <span class="keyword">return</span> <span class="name">fn</span><br />
+<a class="lnum" href="#63" name="63">0063</a>    <span class="keyword">return</span> <span class="name">decorator</span></code></div></body></html>
\ No newline at end of file
--- /dev/null
+This directory exists so that Subversion-based projects can share a single
+copy of the ``ez_setup`` bootstrap module for ``setuptools``, and have it
+automatically updated in their projects when ``setuptools`` is updated.
+
+For your convenience, you may use the following svn:externals definition::
+
+ ez_setup svn://svn.eby-sarna.com/svnroot/ez_setup
+
+You can set this by executing this command in your project directory::
+
+ svn propedit svn:externals .
+
+And then adding the line shown above to the file that comes up for editing.
+Then, whenever you update your project, ``ez_setup`` will be updated as well.
+
--- /dev/null
+#!python
+"""Bootstrap setuptools installation
+
+If you want to use setuptools in your package's setup.py, just include this
+file in the same directory with it, and add this to the top of your setup.py::
+
+ from ez_setup import use_setuptools
+ use_setuptools()
+
+If you want to require a specific version of setuptools, set a download
+mirror, or use an alternate download directory, you can do so by supplying
+the appropriate options to ``use_setuptools()``.
+
+This file can also be run as a script to install or upgrade setuptools.
+"""
+import sys
+DEFAULT_VERSION = "0.6c5"
+DEFAULT_URL = "http://cheeseshop.python.org/packages/%s/s/setuptools/" % sys.version[:3]
+
+md5_data = {
+ 'setuptools-0.6b1-py2.3.egg': '8822caf901250d848b996b7f25c6e6ca',
+ 'setuptools-0.6b1-py2.4.egg': 'b79a8a403e4502fbb85ee3f1941735cb',
+ 'setuptools-0.6b2-py2.3.egg': '5657759d8a6d8fc44070a9d07272d99b',
+ 'setuptools-0.6b2-py2.4.egg': '4996a8d169d2be661fa32a6e52e4f82a',
+ 'setuptools-0.6b3-py2.3.egg': 'bb31c0fc7399a63579975cad9f5a0618',
+ 'setuptools-0.6b3-py2.4.egg': '38a8c6b3d6ecd22247f179f7da669fac',
+ 'setuptools-0.6b4-py2.3.egg': '62045a24ed4e1ebc77fe039aa4e6f7e5',
+ 'setuptools-0.6b4-py2.4.egg': '4cb2a185d228dacffb2d17f103b3b1c4',
+ 'setuptools-0.6c1-py2.3.egg': 'b3f2b5539d65cb7f74ad79127f1a908c',
+ 'setuptools-0.6c1-py2.4.egg': 'b45adeda0667d2d2ffe14009364f2a4b',
+ 'setuptools-0.6c2-py2.3.egg': 'f0064bf6aa2b7d0f3ba0b43f20817c27',
+ 'setuptools-0.6c2-py2.4.egg': '616192eec35f47e8ea16cd6a122b7277',
+ 'setuptools-0.6c3-py2.3.egg': 'f181fa125dfe85a259c9cd6f1d7b78fa',
+ 'setuptools-0.6c3-py2.4.egg': 'e0ed74682c998bfb73bf803a50e7b71e',
+ 'setuptools-0.6c3-py2.5.egg': 'abef16fdd61955514841c7c6bd98965e',
+ 'setuptools-0.6c4-py2.3.egg': 'b0b9131acab32022bfac7f44c5d7971f',
+ 'setuptools-0.6c4-py2.4.egg': '2a1f9656d4fbf3c97bf946c0a124e6e2',
+ 'setuptools-0.6c4-py2.5.egg': '8f5a052e32cdb9c72bcf4b5526f28afc',
+ 'setuptools-0.6c5-py2.3.egg': 'ee9fd80965da04f2f3e6b3576e9d8167',
+ 'setuptools-0.6c5-py2.4.egg': 'afe2adf1c01701ee841761f5bcd8aa64',
+ 'setuptools-0.6c5-py2.5.egg': 'a8d3f61494ccaa8714dfed37bccd3d5d',
+}
+
+import sys, os
+
+def _validate_md5(egg_name, data):
+ if egg_name in md5_data:
+ from md5 import md5
+ digest = md5(data).hexdigest()
+ if digest != md5_data[egg_name]:
+ print >>sys.stderr, (
+ "md5 validation of %s failed! (Possible download problem?)"
+ % egg_name
+ )
+ sys.exit(2)
+ return data
+
+
+def use_setuptools(
+ version=DEFAULT_VERSION, download_base=DEFAULT_URL, to_dir=os.curdir,
+ download_delay=15
+):
+ """Automatically find/download setuptools and make it available on sys.path
+
+ `version` should be a valid setuptools version number that is available
+ as an egg for download under the `download_base` URL (which should end with
+ a '/'). `to_dir` is the directory where setuptools will be downloaded, if
+ it is not already available. If `download_delay` is specified, it should
+ be the number of seconds that will be paused before initiating a download,
+ should one be required. If an older version of setuptools is installed,
+ this routine will print a message to ``sys.stderr`` and raise SystemExit in
+ an attempt to abort the calling script.
+ """
+ try:
+ import setuptools
+ if setuptools.__version__ == '0.0.1':
+ print >>sys.stderr, (
+ "You have an obsolete version of setuptools installed. Please\n"
+ "remove it from your system entirely before rerunning this script."
+ )
+ sys.exit(2)
+ except ImportError:
+ egg = download_setuptools(version, download_base, to_dir, download_delay)
+ sys.path.insert(0, egg)
+ import setuptools; setuptools.bootstrap_install_from = egg
+
+ import pkg_resources
+ try:
+ pkg_resources.require("setuptools>="+version)
+
+ except pkg_resources.VersionConflict, e:
+ # XXX could we install in a subprocess here?
+ print >>sys.stderr, (
+ "The required version of setuptools (>=%s) is not available, and\n"
+ "can't be installed while this script is running. Please install\n"
+ " a more recent version first.\n\n(Currently using %r)"
+ ) % (version, e.args[0])
+ sys.exit(2)
+
+def download_setuptools(
+ version=DEFAULT_VERSION, download_base=DEFAULT_URL, to_dir=os.curdir,
+ delay = 15
+):
+ """Download setuptools from a specified location and return its filename
+
+ `version` should be a valid setuptools version number that is available
+ as an egg for download under the `download_base` URL (which should end
+ with a '/'). `to_dir` is the directory where the egg will be downloaded.
+ `delay` is the number of seconds to pause before an actual download attempt.
+ """
+ import urllib2, shutil
+ egg_name = "setuptools-%s-py%s.egg" % (version,sys.version[:3])
+ url = download_base + egg_name
+ saveto = os.path.join(to_dir, egg_name)
+ src = dst = None
+ if not os.path.exists(saveto): # Avoid repeated downloads
+ try:
+ from distutils import log
+ if delay:
+ log.warn("""
+---------------------------------------------------------------------------
+This script requires setuptools version %s to run (even to display
+help). I will attempt to download it for you (from
+%s), but
+you may need to enable firewall access for this script first.
+I will start the download in %d seconds.
+
+(Note: if this machine does not have network access, please obtain the file
+
+ %s
+
+and place it in this directory before rerunning this script.)
+---------------------------------------------------------------------------""",
+ version, download_base, delay, url
+ ); from time import sleep; sleep(delay)
+ log.warn("Downloading %s", url)
+ src = urllib2.urlopen(url)
+ # Read/write all in one block, so we don't create a corrupt file
+ # if the download is interrupted.
+ data = _validate_md5(egg_name, src.read())
+ dst = open(saveto,"wb"); dst.write(data)
+ finally:
+ if src: src.close()
+ if dst: dst.close()
+ return os.path.realpath(saveto)
+
+def main(argv, version=DEFAULT_VERSION):
+ """Install or upgrade setuptools and EasyInstall"""
+
+ try:
+ import setuptools
+ except ImportError:
+ egg = None
+ try:
+ egg = download_setuptools(version, delay=0)
+ sys.path.insert(0,egg)
+ from setuptools.command.easy_install import main
+ return main(list(argv)+[egg]) # we're done here
+ finally:
+ if egg and os.path.exists(egg):
+ os.unlink(egg)
+ else:
+ if setuptools.__version__ == '0.0.1':
+ # tell the user to uninstall obsolete version
+ use_setuptools(version)
+
+ req = "setuptools>="+version
+ import pkg_resources
+ try:
+ pkg_resources.require(req)
+ except pkg_resources.VersionConflict:
+ try:
+ from setuptools.command.easy_install import main
+ except ImportError:
+ from easy_install import main
+ main(list(argv)+[download_setuptools(delay=0)])
+ sys.exit(0) # try to force an exit
+ else:
+ if argv:
+ from setuptools.command.easy_install import main
+ main(argv)
+ else:
+ print "Setuptools version",version,"or greater has been installed."
+ print '(Run "ez_setup.py -U setuptools" to reinstall or upgrade.)'
+
+
+
+def update_md5(filenames):
+ """Update our built-in md5 registry"""
+
+ import re
+ from md5 import md5
+
+ for name in filenames:
+ base = os.path.basename(name)
+ f = open(name,'rb')
+ md5_data[base] = md5(f.read()).hexdigest()
+ f.close()
+
+ data = [" %r: %r,\n" % it for it in md5_data.items()]
+ data.sort()
+ repl = "".join(data)
+
+ import inspect
+ srcfile = inspect.getsourcefile(sys.modules[__name__])
+ f = open(srcfile, 'rb'); src = f.read(); f.close()
+
+ match = re.search("\nmd5_data = {\n([^}]+)}", src)
+ if not match:
+ print >>sys.stderr, "Internal error!"
+ sys.exit(2)
+
+ src = src[:match.start(1)] + repl + src[match.end(1):]
+ f = open(srcfile,'w')
+ f.write(src)
+ f.close()
+
+
+if __name__=='__main__':
+ if len(sys.argv)>2 and sys.argv[1]=='--md5update':
+ update_md5(sys.argv[2:])
+ else:
+ main(sys.argv[1:])
+
+
+
+
+
--- /dev/null
+#!/bin/sh
+/usr/bin/env python -mtimeit -s 'from simplejson.tests.test_pass1 import test_parse' 'test_parse()'
--- /dev/null
+#!/usr/bin/env python
+import os
+import subprocess
+import shutil
+
+PROJECT='simplejson'
+
+def _get_version():
+ from pkg_resources import PathMetadata, Distribution
+ egg_info = PROJECT + '.egg-info'
+ base_dir = os.path.dirname(egg_info)
+ metadata = PathMetadata(base_dir, egg_info)
+ dist_name = os.path.splitext(os.path.basename(egg_info))[0]
+ dist = Distribution(base_dir, project_name=dist_name, metadata=metadata)
+ return dist.version
+VERSION = _get_version()
+
+PUDGE = '/Library/Frameworks/Python.framework/Versions/2.4/bin/pudge'
+#PUDGE = 'pudge'
+
+res = subprocess.call([
+ PUDGE, '-v', '-d', 'docs', '-m', PROJECT,
+ '-l', '%s %s' % (PROJECT, VERSION),
+ '--theme=green'
+])
+if not res:
+ shutil.copyfile('docs/module-simplejson.html', 'docs/index.html')
+raise SystemExit(res)
--- /dev/null
+#!/usr/bin/env python2.4
+from pkg_resources import require
+require('simplejson')
+
+import profile
+
+from simplejson.tests.test_pass1 import test_parse
+
+profile.run("for x in xrange(10): test_parse()")
--- /dev/null
+[egg_info]
+tag_build =
+tag_date = 0
+tag_svn_revision = 0
+
--- /dev/null
+#!/usr/bin/env python
+
+import ez_setup
+ez_setup.use_setuptools()
+
+from setuptools import setup, find_packages, Extension, Feature
+from distutils.command.build_ext import build_ext
+from distutils.errors import CCompilerError
+
+VERSION = '1.7.1'
+DESCRIPTION = "Simple, fast, extensible JSON encoder/decoder for Python"
+LONG_DESCRIPTION = """
+simplejson is a simple, fast, complete, correct and extensible
+JSON <http://json.org> encoder and decoder for Python 2.3+. It is
+pure Python code with no dependencies, but includes an optional C
+extension for a serious speed boost.
+
+simplejson was formerly known as simple_json, but changed its name to
+comply with PEP 8 module naming guidelines.
+
+The encoder may be subclassed to provide serialization in any kind of
+situation, without any special support by the objects to be serialized
+(somewhat like pickle).
+
+The decoder can handle incoming JSON strings of any specified encoding
+(UTF-8 by default).
+"""
+
+CLASSIFIERS = filter(None, map(str.strip,
+"""
+Intended Audience :: Developers
+License :: OSI Approved :: MIT License
+Programming Language :: Python
+Topic :: Software Development :: Libraries :: Python Modules
+""".splitlines()))
+
+
+BUILD_EXT_WARNING="""
+WARNING: The C extension could not be compiled, speedups are not enabled.
+
+Above is the output showing how the compilation failed.
+"""
+
+class ve_build_ext(build_ext):
+ # This class allows C extension building to fail.
+ def build_extension(self, ext):
+ try:
+ build_ext.build_extension(self, ext)
+ except CCompilerError, x:
+ print ('*'*70+'\n')
+ print BUILD_EXT_WARNING
+ print ('*'*70+'\n')
+
+speedups = Feature(
+ "options C speed-enhancement modules",
+ standard=True,
+ ext_modules = [
+ Extension("simplejson._speedups", ["simplejson/_speedups.c"]),
+ ],
+)
+
+setup(
+ name="simplejson",
+ version=VERSION,
+ description=DESCRIPTION,
+ long_description=LONG_DESCRIPTION,
+ classifiers=CLASSIFIERS,
+ author="Bob Ippolito",
+ author_email="bob@redivi.com",
+ url="http://undefined.org/python/#simplejson",
+ license="MIT License",
+ packages=find_packages(exclude=['ez_setup']),
+ platforms=['any'],
+ test_suite="nose.collector",
+ zip_safe=True,
+ entry_points={
+ 'paste.filter_app_factory': ['json = simplejson.jsonfilter:factory'],
+ },
+ features={'speedups': speedups},
+ cmdclass={'build_ext': ve_build_ext},
+)
--- /dev/null
+Metadata-Version: 1.0
+Name: simplejson
+Version: 1.7.1
+Summary: Simple, fast, extensible JSON encoder/decoder for Python
+Home-page: http://undefined.org/python/#simplejson
+Author: Bob Ippolito
+Author-email: bob@redivi.com
+License: MIT License
+Description:
+ simplejson is a simple, fast, complete, correct and extensible
+ JSON <http://json.org> encoder and decoder for Python 2.3+. It is
+ pure Python code with no dependencies, but includes an optional C
+ extension for a serious speed boost.
+
+ simplejson was formerly known as simple_json, but changed its name to
+ comply with PEP 8 module naming guidelines.
+
+ The encoder may be subclassed to provide serialization in any kind of
+ situation, without any special support by the objects to be serialized
+ (somewhat like pickle).
+
+ The decoder can handle incoming JSON strings of any specified encoding
+ (UTF-8 by default).
+
+Platform: any
+Classifier: Intended Audience :: Developers
+Classifier: License :: OSI Approved :: MIT License
+Classifier: Programming Language :: Python
+Classifier: Topic :: Software Development :: Libraries :: Python Modules
--- /dev/null
+LICENSE.txt
+setup.cfg
+setup.py
+docs/class-simplejson.JSONDecoder.html
+docs/class-simplejson.JSONEncoder.html
+docs/class_to_source.js
+docs/index.html
+docs/layout.css
+docs/module-index.html
+docs/module-simplejson-index.html
+docs/module-simplejson.html
+docs/pudge.css
+docs/rst.css
+docs/simplejson/__init__.py.html
+docs/simplejson/decoder.py.html
+docs/simplejson/encoder.py.html
+docs/simplejson/jsonfilter.py.html
+docs/simplejson/scanner.py.html
+ez_setup/README.txt
+ez_setup/__init__.py
+scripts/bench.sh
+scripts/make_docs.py
+scripts/prof.py
+simplejson/__init__.py
+simplejson/_speedups.c
+simplejson/decoder.py
+simplejson/encoder.py
+simplejson/jsonfilter.py
+simplejson/scanner.py
+simplejson.egg-info/PKG-INFO
+simplejson.egg-info/SOURCES.txt
+simplejson.egg-info/dependency_links.txt
+simplejson.egg-info/entry_points.txt
+simplejson.egg-info/top_level.txt
+simplejson.egg-info/zip-safe
+simplejson/tests/__init__.py
+simplejson/tests/test_attacks.py
+simplejson/tests/test_dump.py
+simplejson/tests/test_fail.py
+simplejson/tests/test_indent.py
+simplejson/tests/test_pass1.py
+simplejson/tests/test_pass2.py
+simplejson/tests/test_pass3.py
+simplejson/tests/test_recursion.py
+simplejson/tests/test_separators.py
+simplejson/tests/test_unicode.py
--- /dev/null
+[paste.filter_app_factory]
+json = simplejson.jsonfilter:factory
+
--- /dev/null
+simplejson
--- /dev/null
+r"""
+A simple, fast, extensible JSON encoder and decoder
+
+JSON (JavaScript Object Notation) <http://json.org> is a subset of
+JavaScript syntax (ECMA-262 3rd edition) used as a lightweight data
+interchange format.
+
+simplejson exposes an API familiar to uses of the standard library
+marshal and pickle modules.
+
+Encoding basic Python object hierarchies::
+
+ >>> import simplejson
+ >>> simplejson.dumps(['foo', {'bar': ('baz', None, 1.0, 2)}])
+ '["foo", {"bar": ["baz", null, 1.0, 2]}]'
+ >>> print simplejson.dumps("\"foo\bar")
+ "\"foo\bar"
+ >>> print simplejson.dumps(u'\u1234')
+ "\u1234"
+ >>> print simplejson.dumps('\\')
+ "\\"
+ >>> print simplejson.dumps({"c": 0, "b": 0, "a": 0}, sort_keys=True)
+ {"a": 0, "b": 0, "c": 0}
+ >>> from StringIO import StringIO
+ >>> io = StringIO()
+ >>> simplejson.dump(['streaming API'], io)
+ >>> io.getvalue()
+ '["streaming API"]'
+
+Compact encoding::
+
+ >>> import simplejson
+ >>> simplejson.dumps([1,2,3,{'4': 5, '6': 7}], separators=(',',':'))
+ '[1,2,3,{"4":5,"6":7}]'
+
+Pretty printing::
+
+ >>> import simplejson
+ >>> print simplejson.dumps({'4': 5, '6': 7}, sort_keys=True, indent=4)
+ {
+ "4": 5,
+ "6": 7
+ }
+
+Decoding JSON::
+
+ >>> import simplejson
+ >>> simplejson.loads('["foo", {"bar":["baz", null, 1.0, 2]}]')
+ [u'foo', {u'bar': [u'baz', None, 1.0, 2]}]
+ >>> simplejson.loads('"\\"foo\\bar"')
+ u'"foo\x08ar'
+ >>> from StringIO import StringIO
+ >>> io = StringIO('["streaming API"]')
+ >>> simplejson.load(io)
+ [u'streaming API']
+
+Specializing JSON object decoding::
+
+ >>> import simplejson
+ >>> def as_complex(dct):
+ ... if '__complex__' in dct:
+ ... return complex(dct['real'], dct['imag'])
+ ... return dct
+ ...
+ >>> simplejson.loads('{"__complex__": true, "real": 1, "imag": 2}',
+ ... object_hook=as_complex)
+ (1+2j)
+
+Extending JSONEncoder::
+
+ >>> import simplejson
+ >>> class ComplexEncoder(simplejson.JSONEncoder):
+ ... def default(self, obj):
+ ... if isinstance(obj, complex):
+ ... return [obj.real, obj.imag]
+ ... return simplejson.JSONEncoder.default(self, obj)
+ ...
+ >>> dumps(2 + 1j, cls=ComplexEncoder)
+ '[2.0, 1.0]'
+ >>> ComplexEncoder().encode(2 + 1j)
+ '[2.0, 1.0]'
+ >>> list(ComplexEncoder().iterencode(2 + 1j))
+ ['[', '2.0', ', ', '1.0', ']']
+
+
+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.
+"""
+__version__ = '1.7.1'
+__all__ = [
+ 'dump', 'dumps', 'load', 'loads',
+ 'JSONDecoder', 'JSONEncoder',
+]
+
+from decoder import JSONDecoder
+from encoder import JSONEncoder
+
+_default_encoder = JSONEncoder(
+ skipkeys=False,
+ ensure_ascii=True,
+ check_circular=True,
+ allow_nan=True,
+ indent=None,
+ separators=None,
+ encoding='utf-8'
+)
+
+def dump(obj, fp, skipkeys=False, ensure_ascii=True, check_circular=True,
+ allow_nan=True, cls=None, indent=None, separators=None,
+ encoding='utf-8', **kw):
+ """
+ Serialize ``obj`` as a JSON formatted stream to ``fp`` (a
+ ``.write()``-supporting file-like object).
+
+ If ``skipkeys`` is ``True`` then ``dict`` keys that are not basic types
+ (``str``, ``unicode``, ``int``, ``long``, ``float``, ``bool``, ``None``)
+ will be skipped instead of raising a ``TypeError``.
+
+ If ``ensure_ascii`` is ``False``, then the some chunks written to ``fp``
+ may be ``unicode`` instances, subject to normal Python ``str`` to
+ ``unicode`` coercion rules. Unless ``fp.write()`` explicitly
+ understands ``unicode`` (as in ``codecs.getwriter()``) this is likely
+ to cause an error.
+
+ If ``check_circular`` is ``False``, then the circular reference check
+ for container types will be skipped and a circular reference will
+ result in an ``OverflowError`` (or worse).
+
+ If ``allow_nan`` is ``False``, then it will be a ``ValueError`` to
+ serialize out of range ``float`` values (``nan``, ``inf``, ``-inf``)
+ in strict compliance of the JSON specification, instead of using the
+ JavaScript equivalents (``NaN``, ``Infinity``, ``-Infinity``).
+
+ If ``indent`` is a non-negative integer, then JSON array elements and object
+ members will be pretty-printed with that indent level. An indent level
+ of 0 will only insert newlines. ``None`` is the most compact representation.
+
+ If ``separators`` is an ``(item_separator, dict_separator)`` tuple
+ then it will be used instead of the default ``(', ', ': ')`` separators.
+ ``(',', ':')`` is the most compact JSON representation.
+
+ ``encoding`` is the character encoding for str instances, default is UTF-8.
+
+ To use a custom ``JSONEncoder`` subclass (e.g. one that overrides the
+ ``.default()`` method to serialize additional types), specify it with
+ the ``cls`` kwarg.
+ """
+ # cached encoder
+ if (skipkeys is False and ensure_ascii is True and
+ check_circular is True and allow_nan is True and
+ cls is None and indent is None and separators is None and
+ encoding == 'utf-8' and not kw):
+ iterable = _default_encoder.iterencode(obj)
+ else:
+ if cls is None:
+ cls = JSONEncoder
+ iterable = cls(skipkeys=skipkeys, ensure_ascii=ensure_ascii,
+ check_circular=check_circular, allow_nan=allow_nan, indent=indent,
+ separators=separators, encoding=encoding, **kw).iterencode(obj)
+ # could accelerate with writelines in some versions of Python, at
+ # a debuggability cost
+ for chunk in iterable:
+ fp.write(chunk)
+
+
+def dumps(obj, skipkeys=False, ensure_ascii=True, check_circular=True,
+ allow_nan=True, cls=None, indent=None, separators=None,
+ encoding='utf-8', **kw):
+ """
+ Serialize ``obj`` to a JSON formatted ``str``.
+
+ If ``skipkeys`` is ``True`` then ``dict`` keys that are not basic types
+ (``str``, ``unicode``, ``int``, ``long``, ``float``, ``bool``, ``None``)
+ will be skipped instead of raising a ``TypeError``.
+
+ If ``ensure_ascii`` is ``False``, then the return value will be a
+ ``unicode`` instance subject to normal Python ``str`` to ``unicode``
+ coercion rules instead of being escaped to an ASCII ``str``.
+
+ If ``check_circular`` is ``False``, then the circular reference check
+ for container types will be skipped and a circular reference will
+ result in an ``OverflowError`` (or worse).
+
+ If ``allow_nan`` is ``False``, then it will be a ``ValueError`` to
+ serialize out of range ``float`` values (``nan``, ``inf``, ``-inf``) in
+ strict compliance of the JSON specification, instead of using the
+ JavaScript equivalents (``NaN``, ``Infinity``, ``-Infinity``).
+
+ If ``indent`` is a non-negative integer, then JSON array elements and
+ object members will be pretty-printed with that indent level. An indent
+ level of 0 will only insert newlines. ``None`` is the most compact
+ representation.
+
+ If ``separators`` is an ``(item_separator, dict_separator)`` tuple
+ then it will be used instead of the default ``(', ', ': ')`` separators.
+ ``(',', ':')`` is the most compact JSON representation.
+
+ ``encoding`` is the character encoding for str instances, default is UTF-8.
+
+ To use a custom ``JSONEncoder`` subclass (e.g. one that overrides the
+ ``.default()`` method to serialize additional types), specify it with
+ the ``cls`` kwarg.
+ """
+ # cached encoder
+ if (skipkeys is False and ensure_ascii is True and
+ check_circular is True and allow_nan is True and
+ cls is None and indent is None and separators is None and
+ encoding == 'utf-8' and not kw):
+ return _default_encoder.encode(obj)
+ if cls is None:
+ cls = JSONEncoder
+ return cls(
+ skipkeys=skipkeys, ensure_ascii=ensure_ascii,
+ check_circular=check_circular, allow_nan=allow_nan, indent=indent,
+ separators=separators, encoding=encoding,
+ **kw).encode(obj)
+
+_default_decoder = JSONDecoder(encoding=None, object_hook=None)
+
+def load(fp, encoding=None, cls=None, object_hook=None, **kw):
+ """
+ Deserialize ``fp`` (a ``.read()``-supporting file-like object containing
+ a JSON document) to a Python object.
+
+ If the contents of ``fp`` is encoded with an ASCII based encoding other
+ than utf-8 (e.g. latin-1), then an appropriate ``encoding`` name must
+ be specified. Encodings that are not ASCII based (such as UCS-2) are
+ not allowed, and should be wrapped with
+ ``codecs.getreader(fp)(encoding)``, or simply decoded to a ``unicode``
+ object and passed to ``loads()``
+
+ ``object_hook`` is an optional function that will be called with the
+ result of any object literal decode (a ``dict``). The return value of
+ ``object_hook`` will be used instead of the ``dict``. This feature
+ can be used to implement custom decoders (e.g. JSON-RPC class hinting).
+
+ To use a custom ``JSONDecoder`` subclass, specify it with the ``cls``
+ kwarg.
+ """
+ return loads(fp.read(),
+ encoding=encoding, cls=cls, object_hook=object_hook, **kw)
+
+def loads(s, encoding=None, cls=None, object_hook=None, **kw):
+ """
+ Deserialize ``s`` (a ``str`` or ``unicode`` instance containing a JSON
+ document) to a Python object.
+
+ If ``s`` is a ``str`` instance and is encoded with an ASCII based encoding
+ other than utf-8 (e.g. latin-1) then an appropriate ``encoding`` name
+ must be specified. Encodings that are not ASCII based (such as UCS-2)
+ are not allowed and should be decoded to ``unicode`` first.
+
+ ``object_hook`` is an optional function that will be called with the
+ result of any object literal decode (a ``dict``). The return value of
+ ``object_hook`` will be used instead of the ``dict``. This feature
+ can be used to implement custom decoders (e.g. JSON-RPC class hinting).
+
+ To use a custom ``JSONDecoder`` subclass, specify it with the ``cls``
+ kwarg.
+ """
+ if cls is None and encoding is None and object_hook is None and not kw:
+ return _default_decoder.decode(s)
+ if cls is None:
+ cls = JSONDecoder
+ if object_hook is not None:
+ kw['object_hook'] = object_hook
+ return cls(encoding=encoding, **kw).decode(s)
+
+def read(s):
+ """
+ json-py API compatibility hook. Use loads(s) instead.
+ """
+ import warnings
+ warnings.warn("simplejson.loads(s) should be used instead of read(s)",
+ DeprecationWarning)
+ return loads(s)
+
+def write(obj):
+ """
+ json-py API compatibility hook. Use dumps(s) instead.
+ """
+ import warnings
+ warnings.warn("simplejson.dumps(s) should be used instead of write(s)",
+ DeprecationWarning)
+ return dumps(obj)
+
+
--- /dev/null
+#include "Python.h"
+#if PY_VERSION_HEX < 0x02050000 && !defined(PY_SSIZE_T_MIN)
+typedef int Py_ssize_t;
+#define PY_SSIZE_T_MAX INT_MAX
+#define PY_SSIZE_T_MIN INT_MIN
+#endif
+
+static Py_ssize_t
+ascii_escape_char(Py_UNICODE c, char *output, Py_ssize_t chars);
+static PyObject *
+ascii_escape_unicode(PyObject *pystr);
+static PyObject *
+ascii_escape_str(PyObject *pystr);
+static PyObject *
+py_encode_basestring_ascii(PyObject* self __attribute__((__unused__)), PyObject *pystr);
+void init_speedups(void);
+
+#define S_CHAR(c) (c >= ' ' && c <= '~' && c != '\\' && c != '/' && c != '"')
+
+#define MIN_EXPANSION 6
+#ifdef Py_UNICODE_WIDE
+#define MAX_EXPANSION (2 * MIN_EXPANSION)
+#else
+#define MAX_EXPANSION MIN_EXPANSION
+#endif
+
+static Py_ssize_t
+ascii_escape_char(Py_UNICODE c, char *output, Py_ssize_t chars) {
+ Py_UNICODE x;
+ output[chars++] = '\\';
+ switch (c) {
+ case '/': output[chars++] = (char)c; break;
+ case '\\': output[chars++] = (char)c; break;
+ case '"': output[chars++] = (char)c; break;
+ case '\b': output[chars++] = 'b'; break;
+ case '\f': output[chars++] = 'f'; break;
+ case '\n': output[chars++] = 'n'; break;
+ case '\r': output[chars++] = 'r'; break;
+ case '\t': output[chars++] = 't'; break;
+ default:
+#ifdef Py_UNICODE_WIDE
+ if (c >= 0x10000) {
+ /* UTF-16 surrogate pair */
+ Py_UNICODE v = c - 0x10000;
+ c = 0xd800 | ((v >> 10) & 0x3ff);
+ output[chars++] = 'u';
+ x = (c & 0xf000) >> 12;
+ output[chars++] = (x < 10) ? '0' + x : 'a' + (x - 10);
+ x = (c & 0x0f00) >> 8;
+ output[chars++] = (x < 10) ? '0' + x : 'a' + (x - 10);
+ x = (c & 0x00f0) >> 4;
+ output[chars++] = (x < 10) ? '0' + x : 'a' + (x - 10);
+ x = (c & 0x000f);
+ output[chars++] = (x < 10) ? '0' + x : 'a' + (x - 10);
+ c = 0xdc00 | (v & 0x3ff);
+ output[chars++] = '\\';
+ }
+#endif
+ output[chars++] = 'u';
+ x = (c & 0xf000) >> 12;
+ output[chars++] = (x < 10) ? '0' + x : 'a' + (x - 10);
+ x = (c & 0x0f00) >> 8;
+ output[chars++] = (x < 10) ? '0' + x : 'a' + (x - 10);
+ x = (c & 0x00f0) >> 4;
+ output[chars++] = (x < 10) ? '0' + x : 'a' + (x - 10);
+ x = (c & 0x000f);
+ output[chars++] = (x < 10) ? '0' + x : 'a' + (x - 10);
+ }
+ return chars;
+}
+
+static PyObject *
+ascii_escape_unicode(PyObject *pystr) {
+ Py_ssize_t i;
+ Py_ssize_t input_chars;
+ Py_ssize_t output_size;
+ Py_ssize_t chars;
+ PyObject *rval;
+ char *output;
+ Py_UNICODE *input_unicode;
+
+ input_chars = PyUnicode_GET_SIZE(pystr);
+ input_unicode = PyUnicode_AS_UNICODE(pystr);
+ /* One char input can be up to 6 chars output, estimate 4 of these */
+ output_size = 2 + (MIN_EXPANSION * 4) + input_chars;
+ rval = PyString_FromStringAndSize(NULL, output_size);
+ if (rval == NULL) {
+ return NULL;
+ }
+ output = PyString_AS_STRING(rval);
+ chars = 0;
+ output[chars++] = '"';
+ for (i = 0; i < input_chars; i++) {
+ Py_UNICODE c = input_unicode[i];
+ if (S_CHAR(c)) {
+ output[chars++] = (char)c;
+ } else {
+ chars = ascii_escape_char(c, output, chars);
+ }
+ if (output_size - chars < (1 + MAX_EXPANSION)) {
+ /* There's more than four, so let's resize by a lot */
+ output_size *= 2;
+ /* This is an upper bound */
+ if (output_size > 2 + (input_chars * MAX_EXPANSION)) {
+ output_size = 2 + (input_chars * MAX_EXPANSION);
+ }
+ if (_PyString_Resize(&rval, output_size) == -1) {
+ return NULL;
+ }
+ output = PyString_AS_STRING(rval);
+ }
+ }
+ output[chars++] = '"';
+ if (_PyString_Resize(&rval, chars) == -1) {
+ return NULL;
+ }
+ return rval;
+}
+
+static PyObject *
+ascii_escape_str(PyObject *pystr) {
+ Py_ssize_t i;
+ Py_ssize_t input_chars;
+ Py_ssize_t output_size;
+ Py_ssize_t chars;
+ PyObject *rval;
+ char *output;
+ char *input_str;
+
+ input_chars = PyString_GET_SIZE(pystr);
+ input_str = PyString_AS_STRING(pystr);
+ /* One char input can be up to 6 chars output, estimate 4 of these */
+ output_size = 2 + (MIN_EXPANSION * 4) + input_chars;
+ rval = PyString_FromStringAndSize(NULL, output_size);
+ if (rval == NULL) {
+ return NULL;
+ }
+ output = PyString_AS_STRING(rval);
+ chars = 0;
+ output[chars++] = '"';
+ for (i = 0; i < input_chars; i++) {
+ Py_UNICODE c = (Py_UNICODE)input_str[i];
+ if (S_CHAR(c)) {
+ output[chars++] = (char)c;
+ } else if (c > 0x7F) {
+ /* We hit a non-ASCII character, bail to unicode mode */
+ PyObject *uni;
+ Py_DECREF(rval);
+ uni = PyUnicode_DecodeUTF8(input_str, input_chars, "strict");
+ if (uni == NULL) {
+ return NULL;
+ }
+ rval = ascii_escape_unicode(uni);
+ Py_DECREF(uni);
+ return rval;
+ } else {
+ chars = ascii_escape_char(c, output, chars);
+ }
+ /* An ASCII char can't possibly expand to a surrogate! */
+ if (output_size - chars < (1 + MIN_EXPANSION)) {
+ /* There's more than four, so let's resize by a lot */
+ output_size *= 2;
+ if (output_size > 2 + (input_chars * MIN_EXPANSION)) {
+ output_size = 2 + (input_chars * MIN_EXPANSION);
+ }
+ if (_PyString_Resize(&rval, output_size) == -1) {
+ return NULL;
+ }
+ output = PyString_AS_STRING(rval);
+ }
+ }
+ output[chars++] = '"';
+ if (_PyString_Resize(&rval, chars) == -1) {
+ return NULL;
+ }
+ return rval;
+}
+
+PyDoc_STRVAR(pydoc_encode_basestring_ascii,
+ "encode_basestring_ascii(basestring) -> str\n"
+ "\n"
+ "..."
+);
+
+static PyObject *
+py_encode_basestring_ascii(PyObject* self __attribute__((__unused__)), PyObject *pystr) {
+ /* METH_O */
+ if (PyString_Check(pystr)) {
+ return ascii_escape_str(pystr);
+ } else if (PyUnicode_Check(pystr)) {
+ return ascii_escape_unicode(pystr);
+ }
+ PyErr_SetString(PyExc_TypeError, "first argument must be a string");
+ return NULL;
+}
+
+#define DEFN(n, k) \
+ { \
+ #n, \
+ (PyCFunction)py_ ##n, \
+ k, \
+ pydoc_ ##n \
+ }
+static PyMethodDef speedups_methods[] = {
+ DEFN(encode_basestring_ascii, METH_O),
+ {}
+};
+#undef DEFN
+
+void
+init_speedups(void)
+{
+ PyObject *m;
+ m = Py_InitModule4("_speedups", speedups_methods, NULL, NULL, PYTHON_API_VERSION);
+}
--- /dev/null
+"""
+Implementation of JSONDecoder
+"""
+import re
+
+from simplejson.scanner import Scanner, pattern
+
+FLAGS = re.VERBOSE | re.MULTILINE | re.DOTALL
+
+def _floatconstants():
+ import struct
+ import sys
+ _BYTES = '7FF80000000000007FF0000000000000'.decode('hex')
+ if sys.byteorder != 'big':
+ _BYTES = _BYTES[:8][::-1] + _BYTES[8:][::-1]
+ nan, inf = struct.unpack('dd', _BYTES)
+ return nan, inf, -inf
+
+NaN, PosInf, NegInf = _floatconstants()
+
+def linecol(doc, pos):
+ lineno = doc.count('\n', 0, pos) + 1
+ if lineno == 1:
+ colno = pos
+ else:
+ colno = pos - doc.rindex('\n', 0, pos)
+ return lineno, colno
+
+def errmsg(msg, doc, pos, end=None):
+ lineno, colno = linecol(doc, pos)
+ if end is None:
+ return '%s: line %d column %d (char %d)' % (msg, lineno, colno, pos)
+ endlineno, endcolno = linecol(doc, end)
+ return '%s: line %d column %d - line %d column %d (char %d - %d)' % (
+ msg, lineno, colno, endlineno, endcolno, pos, end)
+
+_CONSTANTS = {
+ '-Infinity': NegInf,
+ 'Infinity': PosInf,
+ 'NaN': NaN,
+ 'true': True,
+ 'false': False,
+ 'null': None,
+}
+
+def JSONConstant(match, context, c=_CONSTANTS):
+ return c[match.group(0)], None
+pattern('(-?Infinity|NaN|true|false|null)')(JSONConstant)
+
+def JSONNumber(match, context):
+ match = JSONNumber.regex.match(match.string, *match.span())
+ integer, frac, exp = match.groups()
+ if frac or exp:
+ res = float(integer + (frac or '') + (exp or ''))
+ else:
+ res = int(integer)
+ return res, None
+pattern(r'(-?(?:0|[1-9]\d*))(\.\d+)?([eE][-+]?\d+)?')(JSONNumber)
+
+STRINGCHUNK = re.compile(r'(.*?)(["\\])', FLAGS)
+BACKSLASH = {
+ '"': u'"', '\\': u'\\', '/': u'/',
+ 'b': u'\b', 'f': u'\f', 'n': u'\n', 'r': u'\r', 't': u'\t',
+}
+
+DEFAULT_ENCODING = "utf-8"
+
+def scanstring(s, end, encoding=None, _b=BACKSLASH, _m=STRINGCHUNK.match):
+ if encoding is None:
+ encoding = DEFAULT_ENCODING
+ chunks = []
+ _append = chunks.append
+ begin = end - 1
+ while 1:
+ chunk = _m(s, end)
+ if chunk is None:
+ raise ValueError(
+ errmsg("Unterminated string starting at", s, begin))
+ end = chunk.end()
+ content, terminator = chunk.groups()
+ if content:
+ if not isinstance(content, unicode):
+ content = unicode(content, encoding)
+ _append(content)
+ if terminator == '"':
+ break
+ try:
+ esc = s[end]
+ except IndexError:
+ raise ValueError(
+ errmsg("Unterminated string starting at", s, begin))
+ if esc != 'u':
+ try:
+ m = _b[esc]
+ except KeyError:
+ raise ValueError(
+ errmsg("Invalid \\escape: %r" % (esc,), s, end))
+ end += 1
+ else:
+ esc = s[end + 1:end + 5]
+ try:
+ m = unichr(int(esc, 16))
+ if len(esc) != 4 or not esc.isalnum():
+ raise ValueError
+ except ValueError:
+ raise ValueError(errmsg("Invalid \\uXXXX escape", s, end))
+ end += 5
+ _append(m)
+ return u''.join(chunks), end
+
+def JSONString(match, context):
+ encoding = getattr(context, 'encoding', None)
+ return scanstring(match.string, match.end(), encoding)
+pattern(r'"')(JSONString)
+
+WHITESPACE = re.compile(r'\s*', FLAGS)
+
+def JSONObject(match, context, _w=WHITESPACE.match):
+ pairs = {}
+ s = match.string
+ end = _w(s, match.end()).end()
+ nextchar = s[end:end + 1]
+ # trivial empty object
+ if nextchar == '}':
+ return pairs, end + 1
+ if nextchar != '"':
+ raise ValueError(errmsg("Expecting property name", s, end))
+ end += 1
+ encoding = getattr(context, 'encoding', None)
+ iterscan = JSONScanner.iterscan
+ while True:
+ key, end = scanstring(s, end, encoding)
+ end = _w(s, end).end()
+ if s[end:end + 1] != ':':
+ raise ValueError(errmsg("Expecting : delimiter", s, end))
+ end = _w(s, end + 1).end()
+ try:
+ value, end = iterscan(s, idx=end, context=context).next()
+ except StopIteration:
+ raise ValueError(errmsg("Expecting object", s, end))
+ pairs[key] = value
+ end = _w(s, end).end()
+ nextchar = s[end:end + 1]
+ end += 1
+ if nextchar == '}':
+ break
+ if nextchar != ',':
+ raise ValueError(errmsg("Expecting , delimiter", s, end - 1))
+ end = _w(s, end).end()
+ nextchar = s[end:end + 1]
+ end += 1
+ if nextchar != '"':
+ raise ValueError(errmsg("Expecting property name", s, end - 1))
+ object_hook = getattr(context, 'object_hook', None)
+ if object_hook is not None:
+ pairs = object_hook(pairs)
+ return pairs, end
+pattern(r'{')(JSONObject)
+
+def JSONArray(match, context, _w=WHITESPACE.match):
+ values = []
+ s = match.string
+ end = _w(s, match.end()).end()
+ # look-ahead for trivial empty array
+ nextchar = s[end:end + 1]
+ if nextchar == ']':
+ return values, end + 1
+ iterscan = JSONScanner.iterscan
+ while True:
+ try:
+ value, end = iterscan(s, idx=end, context=context).next()
+ except StopIteration:
+ raise ValueError(errmsg("Expecting object", s, end))
+ values.append(value)
+ end = _w(s, end).end()
+ nextchar = s[end:end + 1]
+ end += 1
+ if nextchar == ']':
+ break
+ if nextchar != ',':
+ raise ValueError(errmsg("Expecting , delimiter", s, end))
+ end = _w(s, end).end()
+ return values, end
+pattern(r'\[')(JSONArray)
+
+ANYTHING = [
+ JSONObject,
+ JSONArray,
+ JSONString,
+ JSONConstant,
+ JSONNumber,
+]
+
+JSONScanner = Scanner(ANYTHING)
+
+class JSONDecoder(object):
+ """
+ Simple JSON <http://json.org> decoder
+
+ Performs the following translations in decoding:
+
+ +---------------+-------------------+
+ | JSON | Python |
+ +===============+===================+
+ | object | dict |
+ +---------------+-------------------+
+ | array | list |
+ +---------------+-------------------+
+ | string | unicode |
+ +---------------+-------------------+
+ | number (int) | int, long |
+ +---------------+-------------------+
+ | number (real) | float |
+ +---------------+-------------------+
+ | true | True |
+ +---------------+-------------------+
+ | false | False |
+ +---------------+-------------------+
+ | null | None |
+ +---------------+-------------------+
+
+ It also understands ``NaN``, ``Infinity``, and ``-Infinity`` as
+ their corresponding ``float`` values, which is outside the JSON spec.
+ """
+
+ _scanner = Scanner(ANYTHING)
+ __all__ = ['__init__', 'decode', 'raw_decode']
+
+ def __init__(self, encoding=None, object_hook=None):
+ """
+ ``encoding`` determines the encoding used to interpret any ``str``
+ objects decoded by this instance (utf-8 by default). It has no
+ effect when decoding ``unicode`` objects.
+
+ Note that currently only encodings that are a superset of ASCII work,
+ strings of other encodings should be passed in as ``unicode``.
+
+ ``object_hook``, if specified, will be called with the result
+ of every JSON object decoded and its return value will be used in
+ place of the given ``dict``. This can be used to provide custom
+ deserializations (e.g. to support JSON-RPC class hinting).
+ """
+ self.encoding = encoding
+ self.object_hook = object_hook
+
+ def decode(self, s, _w=WHITESPACE.match):
+ """
+ Return the Python representation of ``s`` (a ``str`` or ``unicode``
+ instance containing a JSON document)
+ """
+ obj, end = self.raw_decode(s, idx=_w(s, 0).end())
+ end = _w(s, end).end()
+ if end != len(s):
+ raise ValueError(errmsg("Extra data", s, end, len(s)))
+ return obj
+
+ def raw_decode(self, s, **kw):
+ """
+ Decode a JSON document from ``s`` (a ``str`` or ``unicode`` beginning
+ with a JSON document) and return a 2-tuple of the Python
+ representation and the index in ``s`` where the document ended.
+
+ This can be used to decode a JSON document from a string that may
+ have extraneous data at the end.
+ """
+ kw.setdefault('context', self)
+ try:
+ obj, end = self._scanner.iterscan(s, **kw).next()
+ except StopIteration:
+ raise ValueError("No JSON object could be decoded")
+ return obj, end
+
+__all__ = ['JSONDecoder']
--- /dev/null
+"""
+Implementation of JSONEncoder
+"""
+import re
+try:
+ from simplejson import _speedups
+except ImportError:
+ _speedups = None
+
+ESCAPE = re.compile(r'[\x00-\x19\\"\b\f\n\r\t]')
+ESCAPE_ASCII = re.compile(r'([\\"/]|[^\ -~])')
+ESCAPE_DCT = {
+ # escape all forward slashes to prevent </script> attack
+ '/': '\\/',
+ '\\': '\\\\',
+ '"': '\\"',
+ '\b': '\\b',
+ '\f': '\\f',
+ '\n': '\\n',
+ '\r': '\\r',
+ '\t': '\\t',
+}
+for i in range(0x20):
+ ESCAPE_DCT.setdefault(chr(i), '\\u%04x' % (i,))
+
+# assume this produces an infinity on all machines (probably not guaranteed)
+INFINITY = float('1e66666')
+
+def floatstr(o, allow_nan=True):
+ # Check for specials. Note that this type of test is processor- and/or
+ # platform-specific, so do tests which don't depend on the internals.
+
+ if o != o:
+ text = 'NaN'
+ elif o == INFINITY:
+ text = 'Infinity'
+ elif o == -INFINITY:
+ text = '-Infinity'
+ else:
+ return str(o)
+
+ if not allow_nan:
+ raise ValueError("Out of range float values are not JSON compliant: %r"
+ % (o,))
+
+ return text
+
+
+def encode_basestring(s):
+ """
+ Return a JSON representation of a Python string
+ """
+ def replace(match):
+ return ESCAPE_DCT[match.group(0)]
+ return '"' + ESCAPE.sub(replace, s) + '"'
+
+def encode_basestring_ascii(s):
+ def replace(match):
+ s = match.group(0)
+ try:
+ return ESCAPE_DCT[s]
+ except KeyError:
+ n = ord(s)
+ if n < 0x10000:
+ return '\\u%04x' % (n,)
+ else:
+ # surrogate pair
+ n -= 0x10000
+ s1 = 0xd800 | ((n >> 10) & 0x3ff)
+ s2 = 0xdc00 | (n & 0x3ff)
+ return '\\u%04x\\u%04x' % (s1, s2)
+ return '"' + str(ESCAPE_ASCII.sub(replace, s)) + '"'
+
+try:
+ encode_basestring_ascii = _speedups.encode_basestring_ascii
+ _need_utf8 = True
+except AttributeError:
+ _need_utf8 = False
+
+class JSONEncoder(object):
+ """
+ Extensible JSON <http://json.org> encoder for Python data structures.
+
+ Supports the following objects and types by default:
+
+ +-------------------+---------------+
+ | Python | JSON |
+ +===================+===============+
+ | dict | object |
+ +-------------------+---------------+
+ | list, tuple | array |
+ +-------------------+---------------+
+ | str, unicode | string |
+ +-------------------+---------------+
+ | int, long, float | number |
+ +-------------------+---------------+
+ | True | true |
+ +-------------------+---------------+
+ | False | false |
+ +-------------------+---------------+
+ | None | null |
+ +-------------------+---------------+
+
+ To extend this to recognize other objects, subclass and implement a
+ ``.default()`` method with another method that returns a serializable
+ object for ``o`` if possible, otherwise it should call the superclass
+ implementation (to raise ``TypeError``).
+ """
+ __all__ = ['__init__', 'default', 'encode', 'iterencode']
+ item_separator = ', '
+ key_separator = ': '
+ def __init__(self, skipkeys=False, ensure_ascii=True,
+ check_circular=True, allow_nan=True, sort_keys=False,
+ indent=None, separators=None, encoding='utf-8'):
+ """
+ Constructor for JSONEncoder, with sensible defaults.
+
+ If skipkeys is False, then it is a TypeError to attempt
+ encoding of keys that are not str, int, long, float or None. If
+ skipkeys is True, such items are simply skipped.
+
+ If ensure_ascii is True, the output is guaranteed to be str
+ objects with all incoming unicode characters escaped. If
+ ensure_ascii is false, the output will be unicode object.
+
+ If check_circular is True, then lists, dicts, and custom encoded
+ objects will be checked for circular references during encoding to
+ prevent an infinite recursion (which would cause an OverflowError).
+ Otherwise, no such check takes place.
+
+ If allow_nan is True, then NaN, Infinity, and -Infinity will be
+ encoded as such. This behavior is not JSON specification compliant,
+ but is consistent with most JavaScript based encoders and decoders.
+ Otherwise, it will be a ValueError to encode such floats.
+
+ If sort_keys is True, then the output of dictionaries will be
+ sorted by key; this is useful for regression tests to ensure
+ that JSON serializations can be compared on a day-to-day basis.
+
+ If indent is a non-negative integer, then JSON array
+ elements and object members will be pretty-printed with that
+ indent level. An indent level of 0 will only insert newlines.
+ None is the most compact representation.
+
+ 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.
+
+ 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.
+ """
+
+ self.skipkeys = skipkeys
+ self.ensure_ascii = ensure_ascii
+ self.check_circular = check_circular
+ self.allow_nan = allow_nan
+ self.sort_keys = sort_keys
+ self.indent = indent
+ self.current_indent_level = 0
+ if separators is not None:
+ self.item_separator, self.key_separator = separators
+ self.encoding = encoding
+
+ def _newline_indent(self):
+ return '\n' + (' ' * (self.indent * self.current_indent_level))
+
+ def _iterencode_list(self, lst, markers=None):
+ if not lst:
+ yield '[]'
+ return
+ if markers is not None:
+ markerid = id(lst)
+ if markerid in markers:
+ raise ValueError("Circular reference detected")
+ markers[markerid] = lst
+ yield '['
+ if self.indent is not None:
+ self.current_indent_level += 1
+ newline_indent = self._newline_indent()
+ separator = self.item_separator + newline_indent
+ yield newline_indent
+ else:
+ newline_indent = None
+ separator = self.item_separator
+ first = True
+ for value in lst:
+ if first:
+ first = False
+ else:
+ yield separator
+ for chunk in self._iterencode(value, markers):
+ yield chunk
+ if newline_indent is not None:
+ self.current_indent_level -= 1
+ yield self._newline_indent()
+ yield ']'
+ if markers is not None:
+ del markers[markerid]
+
+ def _iterencode_dict(self, dct, markers=None):
+ if not dct:
+ yield '{}'
+ return
+ if markers is not None:
+ markerid = id(dct)
+ if markerid in markers:
+ raise ValueError("Circular reference detected")
+ markers[markerid] = dct
+ yield '{'
+ key_separator = self.key_separator
+ if self.indent is not None:
+ self.current_indent_level += 1
+ newline_indent = self._newline_indent()
+ item_separator = self.item_separator + newline_indent
+ yield newline_indent
+ else:
+ newline_indent = None
+ item_separator = self.item_separator
+ first = True
+ if self.ensure_ascii:
+ encoder = encode_basestring_ascii
+ else:
+ encoder = encode_basestring
+ allow_nan = self.allow_nan
+ if self.sort_keys:
+ keys = dct.keys()
+ keys.sort()
+ items = [(k, dct[k]) for k in keys]
+ else:
+ items = dct.iteritems()
+ _encoding = self.encoding
+ _do_decode = (_encoding is not None
+ and not (_need_utf8 and _encoding == 'utf-8'))
+ for key, value in items:
+ if isinstance(key, str):
+ if _do_decode:
+ key = key.decode(_encoding)
+ elif isinstance(key, basestring):
+ pass
+ # JavaScript is weakly typed for these, so it makes sense to
+ # also allow them. Many encoders seem to do something like this.
+ elif isinstance(key, float):
+ key = floatstr(key, allow_nan)
+ elif isinstance(key, (int, long)):
+ key = str(key)
+ elif key is True:
+ key = 'true'
+ elif key is False:
+ key = 'false'
+ elif key is None:
+ key = 'null'
+ elif self.skipkeys:
+ continue
+ else:
+ raise TypeError("key %r is not a string" % (key,))
+ if first:
+ first = False
+ else:
+ yield item_separator
+ yield encoder(key)
+ yield key_separator
+ for chunk in self._iterencode(value, markers):
+ yield chunk
+ if newline_indent is not None:
+ self.current_indent_level -= 1
+ yield self._newline_indent()
+ yield '}'
+ if markers is not None:
+ del markers[markerid]
+
+ def _iterencode(self, o, markers=None):
+ if isinstance(o, basestring):
+ if self.ensure_ascii:
+ encoder = encode_basestring_ascii
+ else:
+ encoder = encode_basestring
+ _encoding = self.encoding
+ if (_encoding is not None and isinstance(o, str)
+ and not (_need_utf8 and _encoding == 'utf-8')):
+ o = o.decode(_encoding)
+ yield encoder(o)
+ elif o is None:
+ yield 'null'
+ elif o is True:
+ yield 'true'
+ elif o is False:
+ yield 'false'
+ elif isinstance(o, (int, long)):
+ yield str(o)
+ elif isinstance(o, float):
+ yield floatstr(o, self.allow_nan)
+ elif isinstance(o, (list, tuple)):
+ for chunk in self._iterencode_list(o, markers):
+ yield chunk
+ elif isinstance(o, dict):
+ for chunk in self._iterencode_dict(o, markers):
+ yield chunk
+ else:
+ if markers is not None:
+ markerid = id(o)
+ if markerid in markers:
+ raise ValueError("Circular reference detected")
+ markers[markerid] = o
+ for chunk in self._iterencode_default(o, markers):
+ yield chunk
+ if markers is not None:
+ del markers[markerid]
+
+ def _iterencode_default(self, o, markers=None):
+ newobj = self.default(o)
+ return self._iterencode(newobj, markers)
+
+ def default(self, o):
+ """
+ Implement this method in a subclass such that it returns
+ a serializable object for ``o``, or calls the base implementation
+ (to raise a ``TypeError``).
+
+ For example, to support arbitrary iterators, you could
+ implement default like this::
+
+ def default(self, o):
+ try:
+ iterable = iter(o)
+ except TypeError:
+ pass
+ else:
+ return list(iterable)
+ return JSONEncoder.default(self, o)
+ """
+ raise TypeError("%r is not JSON serializable" % (o,))
+
+ def encode(self, o):
+ """
+ Return a JSON string representation of a Python data structure.
+
+ >>> JSONEncoder().encode({"foo": ["bar", "baz"]})
+ '{"foo":["bar", "baz"]}'
+ """
+ # This is for extremely simple cases and benchmarks...
+ if isinstance(o, basestring):
+ if isinstance(o, str):
+ _encoding = self.encoding
+ if (_encoding is not None
+ and not (_encoding == 'utf-8' and _need_utf8)):
+ o = o.decode(_encoding)
+ return encode_basestring_ascii(o)
+ # This doesn't pass the iterator directly to ''.join() because it
+ # sucks at reporting exceptions. It's going to do this internally
+ # anyway because it uses PySequence_Fast or similar.
+ chunks = list(self.iterencode(o))
+ return ''.join(chunks)
+
+ def iterencode(self, o):
+ """
+ Encode the given object and yield each string
+ representation as available.
+
+ For example::
+
+ for chunk in JSONEncoder().iterencode(bigobject):
+ mysocket.write(chunk)
+ """
+ if self.check_circular:
+ markers = {}
+ else:
+ markers = None
+ return self._iterencode(o, markers)
+
+__all__ = ['JSONEncoder']
--- /dev/null
+import simplejson
+import cgi
+
+class JSONFilter(object):
+ def __init__(self, app, mime_type='text/x-json'):
+ self.app = app
+ self.mime_type = mime_type
+
+ def __call__(self, environ, start_response):
+ # Read JSON POST input to jsonfilter.json if matching mime type
+ response = {'status': '200 OK', 'headers': []}
+ def json_start_response(status, headers):
+ response['status'] = status
+ response['headers'].extend(headers)
+ environ['jsonfilter.mime_type'] = self.mime_type
+ if environ.get('REQUEST_METHOD', '') == 'POST':
+ if environ.get('CONTENT_TYPE', '') == self.mime_type:
+ args = [_ for _ in [environ.get('CONTENT_LENGTH')] if _]
+ data = environ['wsgi.input'].read(*map(int, args))
+ environ['jsonfilter.json'] = simplejson.loads(data)
+ res = simplejson.dumps(self.app(environ, json_start_response))
+ jsonp = cgi.parse_qs(environ.get('QUERY_STRING', '')).get('jsonp')
+ if jsonp:
+ content_type = 'text/javascript'
+ res = ''.join(jsonp + ['(', res, ')'])
+ elif 'Opera' in environ.get('HTTP_USER_AGENT', ''):
+ # Opera has bunk XMLHttpRequest support for most mime types
+ content_type = 'text/plain'
+ else:
+ content_type = self.mime_type
+ headers = [
+ ('Content-type', content_type),
+ ('Content-length', len(res)),
+ ]
+ headers.extend(response['headers'])
+ start_response(response['status'], headers)
+ return [res]
+
+def factory(app, global_conf, **kw):
+ return JSONFilter(app, **kw)
--- /dev/null
+"""
+Iterator based sre token scanner
+"""
+import sre_parse, sre_compile, sre_constants
+from sre_constants import BRANCH, SUBPATTERN
+from re import VERBOSE, MULTILINE, DOTALL
+import re
+
+__all__ = ['Scanner', 'pattern']
+
+FLAGS = (VERBOSE | MULTILINE | DOTALL)
+class Scanner(object):
+ def __init__(self, lexicon, flags=FLAGS):
+ self.actions = [None]
+ # combine phrases into a compound pattern
+ s = sre_parse.Pattern()
+ s.flags = flags
+ p = []
+ for idx, token in enumerate(lexicon):
+ phrase = token.pattern
+ try:
+ subpattern = sre_parse.SubPattern(s,
+ [(SUBPATTERN, (idx + 1, sre_parse.parse(phrase, flags)))])
+ except sre_constants.error:
+ raise
+ p.append(subpattern)
+ self.actions.append(token)
+
+ p = sre_parse.SubPattern(s, [(BRANCH, (None, p))])
+ self.scanner = sre_compile.compile(p)
+
+
+ def iterscan(self, string, idx=0, context=None):
+ """
+ Yield match, end_idx for each match
+ """
+ match = self.scanner.scanner(string, idx).match
+ actions = self.actions
+ lastend = idx
+ end = len(string)
+ while True:
+ m = match()
+ if m is None:
+ break
+ matchbegin, matchend = m.span()
+ if lastend == matchend:
+ break
+ action = actions[m.lastindex]
+ if action is not None:
+ rval, next_pos = action(m, context)
+ if next_pos is not None and next_pos != matchend:
+ # "fast forward" the scanner
+ matchend = next_pos
+ match = self.scanner.scanner(string, matchend).match
+ yield rval, matchend
+ lastend = matchend
+
+def pattern(pattern, flags=FLAGS):
+ def decorator(fn):
+ fn.pattern = pattern
+ fn.regex = re.compile(pattern, flags)
+ return fn
+ return decorator
--- /dev/null
+def test_script_close_attack():
+ import simplejson
+ res = simplejson.dumps('</script>')
+ assert '</script>' not in res
+ res = simplejson.dumps(simplejson.loads('"</script>"'))
+ assert '</script>' not in res
--- /dev/null
+from cStringIO import StringIO
+import simplejson as S
+
+def test_dump():
+ sio = StringIO()
+ S.dump({}, sio)
+ assert sio.getvalue() == '{}'
+
+def test_dumps():
+ assert S.dumps({}) == '{}'
--- /dev/null
+# Fri Dec 30 18:57:26 2005
+JSONDOCS = [
+ # http://json.org/JSON_checker/test/fail1.json
+ '"A JSON payload should be an object or array, not a string."',
+ # http://json.org/JSON_checker/test/fail2.json
+ '["Unclosed array"',
+ # http://json.org/JSON_checker/test/fail3.json
+ '{unquoted_key: "keys must be quoted}',
+ # http://json.org/JSON_checker/test/fail4.json
+ '["extra comma",]',
+ # http://json.org/JSON_checker/test/fail5.json
+ '["double extra comma",,]',
+ # http://json.org/JSON_checker/test/fail6.json
+ '[ , "<-- missing value"]',
+ # http://json.org/JSON_checker/test/fail7.json
+ '["Comma after the close"],',
+ # http://json.org/JSON_checker/test/fail8.json
+ '["Extra close"]]',
+ # http://json.org/JSON_checker/test/fail9.json
+ '{"Extra comma": true,}',
+ # http://json.org/JSON_checker/test/fail10.json
+ '{"Extra value after close": true} "misplaced quoted value"',
+ # http://json.org/JSON_checker/test/fail11.json
+ '{"Illegal expression": 1 + 2}',
+ # http://json.org/JSON_checker/test/fail12.json
+ '{"Illegal invocation": alert()}',
+ # http://json.org/JSON_checker/test/fail13.json
+ '{"Numbers cannot have leading zeroes": 013}',
+ # http://json.org/JSON_checker/test/fail14.json
+ '{"Numbers cannot be hex": 0x14}',
+ # http://json.org/JSON_checker/test/fail15.json
+ '["Illegal backslash escape: \\x15"]',
+ # http://json.org/JSON_checker/test/fail16.json
+ '["Illegal backslash escape: \\\'"]',
+ # http://json.org/JSON_checker/test/fail17.json
+ '["Illegal backslash escape: \\017"]',
+ # http://json.org/JSON_checker/test/fail18.json
+ '[[[[[[[[[[[[[[[[[[[["Too deep"]]]]]]]]]]]]]]]]]]]]',
+ # http://json.org/JSON_checker/test/fail19.json
+ '{"Missing colon" null}',
+ # http://json.org/JSON_checker/test/fail20.json
+ '{"Double colon":: null}',
+ # http://json.org/JSON_checker/test/fail21.json
+ '{"Comma instead of colon", null}',
+ # http://json.org/JSON_checker/test/fail22.json
+ '["Colon instead of comma": false]',
+ # http://json.org/JSON_checker/test/fail23.json
+ '["Bad value", truth]',
+ # http://json.org/JSON_checker/test/fail24.json
+ "['single quote']",
+]
+
+SKIPS = {
+ 1: "why not have a string payload?",
+ 18: "spec doesn't specify any nesting limitations",
+}
+
+def test_failures():
+ import simplejson
+ for idx, doc in enumerate(JSONDOCS):
+ idx = idx + 1
+ if idx in SKIPS:
+ simplejson.loads(doc)
+ continue
+ try:
+ simplejson.loads(doc)
+ except ValueError:
+ pass
+ else:
+ assert False, "Expected failure for fail%d.json: %r" % (idx, doc)
--- /dev/null
+
+
+
+def test_indent():
+ import simplejson
+ import textwrap
+
+ h = [['blorpie'], ['whoops'], [], 'd-shtaeou', 'd-nthiouh', 'i-vhbjkhnth',
+ {'nifty': 87}, {'field': 'yes', 'morefield': False} ]
+
+ expect = textwrap.dedent("""\
+ [
+ [
+ "blorpie"
+ ],
+ [
+ "whoops"
+ ],
+ [],
+ "d-shtaeou",
+ "d-nthiouh",
+ "i-vhbjkhnth",
+ {
+ "nifty": 87
+ },
+ {
+ "field": "yes",
+ "morefield": false
+ }
+ ]""")
+
+
+ d1 = simplejson.dumps(h)
+ d2 = simplejson.dumps(h, indent=2, sort_keys=True, separators=(',', ': '))
+
+ h1 = simplejson.loads(d1)
+ h2 = simplejson.loads(d2)
+
+ assert h1 == h
+ assert h2 == h
+ assert d2 == expect
--- /dev/null
+# from http://json.org/JSON_checker/test/pass1.json
+JSON = r'''
+[
+ "JSON Test Pattern pass1",
+ {"object with 1 member":["array with 1 element"]},
+ {},
+ [],
+ -42,
+ true,
+ false,
+ null,
+ {
+ "integer": 1234567890,
+ "real": -9876.543210,
+ "e": 0.123456789e-12,
+ "E": 1.234567890E+34,
+ "": 23456789012E666,
+ "zero": 0,
+ "one": 1,
+ "space": " ",
+ "quote": "\"",
+ "backslash": "\\",
+ "controls": "\b\f\n\r\t",
+ "slash": "/ & \/",
+ "alpha": "abcdefghijklmnopqrstuvwyz",
+ "ALPHA": "ABCDEFGHIJKLMNOPQRSTUVWYZ",
+ "digit": "0123456789",
+ "special": "`1~!@#$%^&*()_+-={':[,]}|;.</>?",
+ "hex": "\u0123\u4567\u89AB\uCDEF\uabcd\uef4A",
+ "true": true,
+ "false": false,
+ "null": null,
+ "array":[ ],
+ "object":{ },
+ "address": "50 St. James Street",
+ "url": "http://www.JSON.org/",
+ "comment": "// /* <!-- --",
+ "# -- --> */": " ",
+ " s p a c e d " :[1,2 , 3
+
+,
+
+4 , 5 , 6 ,7 ],
+ "compact": [1,2,3,4,5,6,7],
+ "jsontext": "{\"object with 1 member\":[\"array with 1 element\"]}",
+ "quotes": "" \u0022 %22 0x22 034 "",
+ "\/\\\"\uCAFE\uBABE\uAB98\uFCDE\ubcda\uef4A\b\f\n\r\t`1~!@#$%^&*()_+-=[]{}|;:',./<>?"
+: "A key can be any string"
+ },
+ 0.5 ,98.6
+,
+99.44
+,
+
+1066
+
+
+,"rosebud"]
+'''
+
+def test_parse():
+ # test in/out equivalence and parsing
+ import simplejson
+ res = simplejson.loads(JSON)
+ out = simplejson.dumps(res)
+ assert res == simplejson.loads(out)
+ try:
+ simplejson.dumps(res, allow_nan=False)
+ except ValueError:
+ pass
+ else:
+ assert False, "23456789012E666 should be out of range"
--- /dev/null
+# from http://json.org/JSON_checker/test/pass2.json
+JSON = r'''
+[[[[[[[[[[[[[[[[[[["Not too deep"]]]]]]]]]]]]]]]]]]]
+'''
+
+def test_parse():
+ # test in/out equivalence and parsing
+ import simplejson
+ res = simplejson.loads(JSON)
+ out = simplejson.dumps(res)
+ assert res == simplejson.loads(out)
--- /dev/null
+# from http://json.org/JSON_checker/test/pass3.json
+JSON = r'''
+{
+ "JSON Test Pattern pass3": {
+ "The outermost value": "must be an object or array.",
+ "In this test": "It is an object."
+ }
+}
+'''
+
+def test_parse():
+ # test in/out equivalence and parsing
+ import simplejson
+ res = simplejson.loads(JSON)
+ out = simplejson.dumps(res)
+ assert res == simplejson.loads(out)
--- /dev/null
+import simplejson
+
+def test_listrecursion():
+ x = []
+ x.append(x)
+ try:
+ simplejson.dumps(x)
+ except ValueError:
+ pass
+ else:
+ assert False, "didn't raise ValueError on list recursion"
+ x = []
+ y = [x]
+ x.append(y)
+ try:
+ simplejson.dumps(x)
+ except ValueError:
+ pass
+ else:
+ assert False, "didn't raise ValueError on alternating list recursion"
+ y = []
+ x = [y, y]
+ # ensure that the marker is cleared
+ simplejson.dumps(x)
+
+def test_dictrecursion():
+ x = {}
+ x["test"] = x
+ try:
+ simplejson.dumps(x)
+ except ValueError:
+ pass
+ else:
+ assert False, "didn't raise ValueError on dict recursion"
+ x = {}
+ y = {"a": x, "b": x}
+ # ensure that the marker is cleared
+ simplejson.dumps(x)
+
+class TestObject:
+ pass
+
+class RecursiveJSONEncoder(simplejson.JSONEncoder):
+ recurse = False
+ def default(self, o):
+ if o is TestObject:
+ if self.recurse:
+ return [TestObject]
+ else:
+ return 'TestObject'
+ simplejson.JSONEncoder.default(o)
+
+def test_defaultrecursion():
+ enc = RecursiveJSONEncoder()
+ assert enc.encode(TestObject) == '"TestObject"'
+ enc.recurse = True
+ try:
+ enc.encode(TestObject)
+ except ValueError:
+ pass
+ else:
+ assert False, "didn't raise ValueError on default recursion"
--- /dev/null
+
+
+
+def test_separators():
+ import simplejson
+ import textwrap
+
+ h = [['blorpie'], ['whoops'], [], 'd-shtaeou', 'd-nthiouh', 'i-vhbjkhnth',
+ {'nifty': 87}, {'field': 'yes', 'morefield': False} ]
+
+ expect = textwrap.dedent("""\
+ [
+ [
+ "blorpie"
+ ] ,
+ [
+ "whoops"
+ ] ,
+ [] ,
+ "d-shtaeou" ,
+ "d-nthiouh" ,
+ "i-vhbjkhnth" ,
+ {
+ "nifty" : 87
+ } ,
+ {
+ "field" : "yes" ,
+ "morefield" : false
+ }
+ ]""")
+
+
+ d1 = simplejson.dumps(h)
+ d2 = simplejson.dumps(h, indent=2, sort_keys=True, separators=(' ,', ' : '))
+
+ h1 = simplejson.loads(d1)
+ h2 = simplejson.loads(d2)
+
+ assert h1 == h
+ assert h2 == h
+ assert d2 == expect
--- /dev/null
+import simplejson as S
+
+def test_encoding1():
+ encoder = S.JSONEncoder(encoding='utf-8')
+ u = u'\N{GREEK SMALL LETTER ALPHA}\N{GREEK CAPITAL LETTER OMEGA}'
+ s = u.encode('utf-8')
+ ju = encoder.encode(u)
+ js = encoder.encode(s)
+ assert ju == js
+
+def test_encoding2():
+ u = u'\N{GREEK SMALL LETTER ALPHA}\N{GREEK CAPITAL LETTER OMEGA}'
+ s = u.encode('utf-8')
+ ju = S.dumps(u, encoding='utf-8')
+ js = S.dumps(s, encoding='utf-8')
+ assert ju == js