pygments.rb 1.2.1 → 2.0.0.rc2
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +5 -5
- data/.github/dependabot.yml +13 -0
- data/.github/workflows/ci.yml +28 -0
- data/.github/workflows/release.yml +24 -0
- data/.gitignore +5 -6
- data/CHANGELOG.adoc +119 -0
- data/Gemfile +3 -1
- data/LICENSE +1 -1
- data/README.adoc +161 -0
- data/Rakefile +10 -21
- data/bench.rb +8 -7
- data/cache-lexers.rb +3 -2
- data/lib/pygments.rb +10 -11
- data/lib/pygments/lexer.rb +5 -5
- data/lib/pygments/mentos.py +23 -66
- data/lib/pygments/popen.rb +152 -204
- data/lib/pygments/version.rb +2 -2
- data/pygments.rb.gemspec +11 -9
- data/test/test_pygments.rb +51 -84
- data/vendor/pygments-main/{AUTHORS → Pygments-2.7.3.dist-info/AUTHORS} +21 -3
- data/vendor/pygments-main/Pygments-2.7.3.dist-info/INSTALLER +1 -0
- data/vendor/pygments-main/{LICENSE → Pygments-2.7.3.dist-info/LICENSE} +1 -1
- data/vendor/pygments-main/Pygments-2.7.3.dist-info/METADATA +49 -0
- data/vendor/pygments-main/Pygments-2.7.3.dist-info/RECORD +482 -0
- data/vendor/pygments-main/Pygments-2.7.3.dist-info/REQUESTED +0 -0
- data/vendor/pygments-main/Pygments-2.7.3.dist-info/WHEEL +5 -0
- data/vendor/pygments-main/Pygments-2.7.3.dist-info/entry_points.txt +3 -0
- data/vendor/pygments-main/Pygments-2.7.3.dist-info/top_level.txt +1 -0
- data/vendor/pygments-main/bin/pygmentize +8 -0
- data/vendor/pygments-main/pygments/__init__.py +6 -11
- data/vendor/pygments-main/pygments/__main__.py +18 -0
- data/vendor/pygments-main/pygments/cmdline.py +38 -29
- data/vendor/pygments-main/pygments/console.py +6 -9
- data/vendor/pygments-main/pygments/filter.py +4 -6
- data/vendor/pygments-main/pygments/filters/__init__.py +609 -21
- data/vendor/pygments-main/pygments/formatter.py +4 -4
- data/vendor/pygments-main/pygments/formatters/__init__.py +9 -8
- data/vendor/pygments-main/pygments/formatters/_mapping.py +1 -3
- data/vendor/pygments-main/pygments/formatters/bbcode.py +1 -1
- data/vendor/pygments-main/pygments/formatters/html.py +223 -135
- data/vendor/pygments-main/pygments/formatters/img.py +68 -41
- data/vendor/pygments-main/pygments/formatters/irc.py +39 -39
- data/vendor/pygments-main/pygments/formatters/latex.py +56 -26
- data/vendor/pygments-main/pygments/formatters/other.py +12 -8
- data/vendor/pygments-main/pygments/formatters/rtf.py +29 -29
- data/vendor/pygments-main/pygments/formatters/svg.py +38 -4
- data/vendor/pygments-main/pygments/formatters/terminal.py +25 -31
- data/vendor/pygments-main/pygments/formatters/terminal256.py +22 -12
- data/vendor/pygments-main/pygments/lexer.py +41 -39
- data/vendor/pygments-main/pygments/lexers/__init__.py +342 -0
- data/vendor/pygments-main/pygments/lexers/_asy_builtins.py +1645 -0
- data/vendor/pygments-main/pygments/lexers/_cl_builtins.py +232 -0
- data/vendor/pygments-main/pygments/lexers/_cocoa_builtins.py +71 -0
- data/vendor/pygments-main/pygments/lexers/_csound_builtins.py +1725 -0
- data/vendor/pygments-main/pygments/lexers/_lasso_builtins.py +5327 -0
- data/vendor/pygments-main/pygments/lexers/_lua_builtins.py +293 -0
- data/vendor/pygments-main/pygments/lexers/_mapping.py +551 -0
- data/vendor/pygments-main/pygments/lexers/_mql_builtins.py +1172 -0
- data/vendor/pygments-main/pygments/lexers/_mysql_builtins.py +1282 -0
- data/vendor/pygments-main/pygments/lexers/_openedge_builtins.py +2547 -0
- data/vendor/pygments-main/pygments/lexers/_php_builtins.py +4753 -0
- data/vendor/pygments-main/pygments/lexers/_postgres_builtins.py +678 -0
- data/vendor/pygments-main/pygments/lexers/_scilab_builtins.py +3094 -0
- data/vendor/pygments-main/pygments/lexers/_sourcemod_builtins.py +1161 -0
- data/vendor/pygments-main/pygments/lexers/_stan_builtins.py +558 -0
- data/vendor/pygments-main/pygments/lexers/_stata_builtins.py +421 -0
- data/vendor/pygments-main/pygments/lexers/_tsql_builtins.py +1004 -0
- data/vendor/pygments-main/pygments/lexers/_usd_builtins.py +113 -0
- data/vendor/pygments-main/pygments/lexers/_vbscript_builtins.py +280 -0
- data/vendor/pygments-main/pygments/lexers/_vim_builtins.py +1939 -0
- data/vendor/pygments-main/pygments/lexers/actionscript.py +245 -0
- data/vendor/pygments-main/pygments/lexers/agile.py +24 -0
- data/vendor/pygments-main/pygments/lexers/algebra.py +240 -0
- data/vendor/pygments-main/pygments/lexers/ambient.py +76 -0
- data/vendor/pygments-main/pygments/lexers/ampl.py +87 -0
- data/vendor/pygments-main/pygments/lexers/apl.py +101 -0
- data/vendor/pygments-main/pygments/lexers/archetype.py +318 -0
- data/vendor/pygments-main/pygments/lexers/arrow.py +117 -0
- data/vendor/pygments-main/pygments/lexers/asm.py +1005 -0
- data/vendor/pygments-main/pygments/lexers/automation.py +374 -0
- data/vendor/pygments-main/pygments/lexers/bare.py +104 -0
- data/vendor/pygments-main/pygments/lexers/basic.py +662 -0
- data/vendor/pygments-main/pygments/lexers/bibtex.py +160 -0
- data/vendor/pygments-main/pygments/lexers/boa.py +102 -0
- data/vendor/pygments-main/pygments/lexers/business.py +627 -0
- data/vendor/pygments-main/pygments/lexers/c_cpp.py +344 -0
- data/vendor/pygments-main/pygments/lexers/c_like.py +566 -0
- data/vendor/pygments-main/pygments/lexers/capnproto.py +78 -0
- data/vendor/pygments-main/pygments/lexers/chapel.py +112 -0
- data/vendor/pygments-main/pygments/lexers/clean.py +179 -0
- data/vendor/pygments-main/pygments/lexers/compiled.py +34 -0
- data/vendor/pygments-main/pygments/lexers/configs.py +984 -0
- data/vendor/pygments-main/pygments/lexers/console.py +114 -0
- data/vendor/pygments-main/pygments/lexers/crystal.py +392 -0
- data/vendor/pygments-main/pygments/lexers/csound.py +467 -0
- data/vendor/pygments-main/pygments/lexers/css.py +691 -0
- data/vendor/pygments-main/pygments/lexers/d.py +256 -0
- data/vendor/pygments-main/pygments/lexers/dalvik.py +125 -0
- data/vendor/pygments-main/pygments/lexers/data.py +698 -0
- data/vendor/pygments-main/pygments/lexers/devicetree.py +109 -0
- data/vendor/pygments-main/pygments/lexers/diff.py +165 -0
- data/vendor/pygments-main/pygments/lexers/dotnet.py +707 -0
- data/vendor/pygments-main/pygments/lexers/dsls.py +960 -0
- data/vendor/pygments-main/pygments/lexers/dylan.py +287 -0
- data/vendor/pygments-main/pygments/lexers/ecl.py +139 -0
- data/vendor/pygments-main/pygments/lexers/eiffel.py +65 -0
- data/vendor/pygments-main/pygments/lexers/elm.py +121 -0
- data/vendor/pygments-main/pygments/lexers/email.py +151 -0
- data/vendor/pygments-main/pygments/lexers/erlang.py +530 -0
- data/vendor/pygments-main/pygments/lexers/esoteric.py +304 -0
- data/vendor/pygments-main/pygments/lexers/ezhil.py +77 -0
- data/vendor/pygments-main/pygments/lexers/factor.py +344 -0
- data/vendor/pygments-main/pygments/lexers/fantom.py +250 -0
- data/vendor/pygments-main/pygments/lexers/felix.py +273 -0
- data/vendor/pygments-main/pygments/lexers/floscript.py +83 -0
- data/vendor/pygments-main/pygments/lexers/forth.py +178 -0
- data/vendor/pygments-main/pygments/lexers/fortran.py +206 -0
- data/vendor/pygments-main/pygments/lexers/foxpro.py +428 -0
- data/vendor/pygments-main/pygments/lexers/freefem.py +898 -0
- data/vendor/pygments-main/pygments/lexers/functional.py +21 -0
- data/vendor/pygments-main/pygments/lexers/gdscript.py +346 -0
- data/vendor/pygments-main/pygments/lexers/go.py +101 -0
- data/vendor/pygments-main/pygments/lexers/grammar_notation.py +270 -0
- data/vendor/pygments-main/pygments/lexers/graph.py +85 -0
- data/vendor/pygments-main/pygments/lexers/graphics.py +800 -0
- data/vendor/pygments-main/pygments/lexers/haskell.py +870 -0
- data/vendor/pygments-main/pygments/lexers/haxe.py +936 -0
- data/vendor/pygments-main/pygments/lexers/hdl.py +472 -0
- data/vendor/pygments-main/pygments/lexers/hexdump.py +103 -0
- data/vendor/pygments-main/pygments/lexers/html.py +614 -0
- data/vendor/pygments-main/pygments/lexers/idl.py +281 -0
- data/vendor/pygments-main/pygments/lexers/igor.py +420 -0
- data/vendor/pygments-main/pygments/lexers/inferno.py +96 -0
- data/vendor/pygments-main/pygments/lexers/installers.py +322 -0
- data/vendor/pygments-main/pygments/lexers/int_fiction.py +1368 -0
- data/vendor/pygments-main/pygments/lexers/iolang.py +63 -0
- data/vendor/pygments-main/pygments/lexers/j.py +146 -0
- data/vendor/pygments-main/pygments/lexers/javascript.py +1540 -0
- data/vendor/pygments-main/pygments/lexers/julia.py +331 -0
- data/vendor/pygments-main/pygments/lexers/jvm.py +1673 -0
- data/vendor/pygments-main/pygments/lexers/lisp.py +2699 -0
- data/vendor/pygments-main/pygments/lexers/make.py +206 -0
- data/vendor/pygments-main/pygments/lexers/markup.py +765 -0
- data/vendor/pygments-main/pygments/lexers/math.py +21 -0
- data/vendor/pygments-main/pygments/lexers/matlab.py +720 -0
- data/vendor/pygments-main/pygments/lexers/mime.py +226 -0
- data/vendor/pygments-main/pygments/lexers/ml.py +958 -0
- data/vendor/pygments-main/pygments/lexers/modeling.py +366 -0
- data/vendor/pygments-main/pygments/lexers/modula2.py +1580 -0
- data/vendor/pygments-main/pygments/lexers/monte.py +204 -0
- data/vendor/pygments-main/pygments/lexers/mosel.py +448 -0
- data/vendor/pygments-main/pygments/lexers/ncl.py +894 -0
- data/vendor/pygments-main/pygments/lexers/nimrod.py +159 -0
- data/vendor/pygments-main/pygments/lexers/nit.py +64 -0
- data/vendor/pygments-main/pygments/lexers/nix.py +136 -0
- data/vendor/pygments-main/pygments/lexers/oberon.py +121 -0
- data/vendor/pygments-main/pygments/lexers/objective.py +504 -0
- data/vendor/pygments-main/pygments/lexers/ooc.py +85 -0
- data/vendor/pygments-main/pygments/lexers/other.py +41 -0
- data/vendor/pygments-main/pygments/lexers/parasail.py +79 -0
- data/vendor/pygments-main/pygments/lexers/parsers.py +800 -0
- data/vendor/pygments-main/pygments/lexers/pascal.py +644 -0
- data/vendor/pygments-main/pygments/lexers/pawn.py +205 -0
- data/vendor/pygments-main/pygments/lexers/perl.py +732 -0
- data/vendor/pygments-main/pygments/lexers/php.py +321 -0
- data/vendor/pygments-main/pygments/lexers/pointless.py +71 -0
- data/vendor/pygments-main/pygments/lexers/pony.py +94 -0
- data/vendor/pygments-main/pygments/lexers/praat.py +302 -0
- data/vendor/pygments-main/pygments/lexers/prolog.py +306 -0
- data/vendor/pygments-main/pygments/lexers/promql.py +183 -0
- data/vendor/pygments-main/pygments/lexers/python.py +1151 -0
- data/vendor/pygments-main/pygments/lexers/qvt.py +152 -0
- data/vendor/pygments-main/pygments/lexers/r.py +191 -0
- data/vendor/pygments-main/pygments/lexers/rdf.py +463 -0
- data/vendor/pygments-main/pygments/lexers/rebol.py +431 -0
- data/vendor/pygments-main/pygments/lexers/resource.py +85 -0
- data/vendor/pygments-main/pygments/lexers/ride.py +139 -0
- data/vendor/pygments-main/pygments/lexers/rnc.py +67 -0
- data/vendor/pygments-main/pygments/lexers/roboconf.py +82 -0
- data/vendor/pygments-main/pygments/lexers/robotframework.py +552 -0
- data/vendor/pygments-main/pygments/lexers/ruby.py +517 -0
- data/vendor/pygments-main/pygments/lexers/rust.py +224 -0
- data/vendor/pygments-main/pygments/lexers/sas.py +228 -0
- data/vendor/pygments-main/pygments/lexers/scdoc.py +83 -0
- data/vendor/pygments-main/pygments/lexers/scripting.py +1284 -0
- data/vendor/pygments-main/pygments/lexers/sgf.py +61 -0
- data/vendor/pygments-main/pygments/lexers/shell.py +914 -0
- data/vendor/pygments-main/pygments/lexers/sieve.py +69 -0
- data/vendor/pygments-main/pygments/lexers/slash.py +185 -0
- data/vendor/pygments-main/pygments/lexers/smalltalk.py +195 -0
- data/vendor/pygments-main/pygments/lexers/smv.py +79 -0
- data/vendor/pygments-main/pygments/lexers/snobol.py +83 -0
- data/vendor/pygments-main/pygments/lexers/solidity.py +92 -0
- data/vendor/pygments-main/pygments/lexers/special.py +105 -0
- data/vendor/pygments-main/pygments/lexers/sql.py +837 -0
- data/vendor/pygments-main/pygments/lexers/stata.py +171 -0
- data/vendor/pygments-main/pygments/lexers/supercollider.py +95 -0
- data/vendor/pygments-main/pygments/lexers/tcl.py +145 -0
- data/vendor/pygments-main/pygments/lexers/templates.py +2264 -0
- data/vendor/pygments-main/pygments/lexers/teraterm.py +335 -0
- data/vendor/pygments-main/pygments/lexers/testing.py +207 -0
- data/vendor/pygments-main/pygments/lexers/text.py +26 -0
- data/vendor/pygments-main/pygments/lexers/textedit.py +169 -0
- data/vendor/pygments-main/pygments/lexers/textfmts.py +430 -0
- data/vendor/pygments-main/pygments/lexers/theorem.py +474 -0
- data/vendor/pygments-main/pygments/lexers/tnt.py +263 -0
- data/vendor/pygments-main/pygments/lexers/trafficscript.py +54 -0
- data/vendor/pygments-main/pygments/lexers/typoscript.py +219 -0
- data/vendor/pygments-main/pygments/lexers/unicon.py +412 -0
- data/vendor/pygments-main/pygments/lexers/urbi.py +146 -0
- data/vendor/pygments-main/pygments/lexers/usd.py +90 -0
- data/vendor/pygments-main/pygments/lexers/varnish.py +190 -0
- data/vendor/pygments-main/pygments/lexers/verification.py +114 -0
- data/vendor/pygments-main/pygments/lexers/web.py +24 -0
- data/vendor/pygments-main/pygments/lexers/webidl.py +299 -0
- data/vendor/pygments-main/pygments/lexers/webmisc.py +991 -0
- data/vendor/pygments-main/pygments/lexers/whiley.py +116 -0
- data/vendor/pygments-main/pygments/lexers/x10.py +69 -0
- data/vendor/pygments-main/pygments/lexers/xorg.py +37 -0
- data/vendor/pygments-main/pygments/lexers/yang.py +104 -0
- data/vendor/pygments-main/pygments/lexers/zig.py +124 -0
- data/vendor/pygments-main/pygments/modeline.py +1 -1
- data/vendor/pygments-main/pygments/plugin.py +4 -2
- data/vendor/pygments-main/pygments/regexopt.py +1 -1
- data/vendor/pygments-main/pygments/scanner.py +2 -2
- data/vendor/pygments-main/pygments/sphinxext.py +2 -4
- data/vendor/pygments-main/pygments/style.py +61 -24
- data/vendor/pygments-main/pygments/styles/__init__.py +10 -4
- data/vendor/pygments-main/pygments/styles/abap.py +1 -1
- data/vendor/pygments-main/pygments/styles/algol.py +1 -1
- data/vendor/pygments-main/pygments/styles/algol_nu.py +1 -1
- data/vendor/pygments-main/pygments/styles/arduino.py +2 -2
- data/vendor/pygments-main/pygments/styles/autumn.py +1 -1
- data/vendor/pygments-main/pygments/styles/borland.py +1 -1
- data/vendor/pygments-main/pygments/styles/bw.py +1 -1
- data/vendor/pygments-main/pygments/styles/colorful.py +1 -1
- data/vendor/pygments-main/pygments/styles/default.py +1 -1
- data/vendor/pygments-main/pygments/styles/emacs.py +1 -1
- data/vendor/pygments-main/pygments/styles/friendly.py +1 -1
- data/vendor/pygments-main/pygments/styles/fruity.py +1 -1
- data/vendor/pygments-main/pygments/styles/igor.py +1 -1
- data/vendor/pygments-main/pygments/styles/inkpot.py +67 -0
- data/vendor/pygments-main/pygments/styles/lovelace.py +1 -1
- data/vendor/pygments-main/pygments/styles/manni.py +1 -1
- data/vendor/pygments-main/pygments/styles/monokai.py +4 -3
- data/vendor/pygments-main/pygments/styles/murphy.py +1 -1
- data/vendor/pygments-main/pygments/styles/native.py +1 -1
- data/vendor/pygments-main/pygments/styles/paraiso_dark.py +1 -1
- data/vendor/pygments-main/pygments/styles/paraiso_light.py +1 -1
- data/vendor/pygments-main/pygments/styles/pastie.py +1 -1
- data/vendor/pygments-main/pygments/styles/perldoc.py +1 -1
- data/vendor/pygments-main/pygments/styles/rainbow_dash.py +1 -1
- data/vendor/pygments-main/pygments/styles/rrt.py +1 -1
- data/vendor/pygments-main/pygments/styles/sas.py +1 -1
- data/vendor/pygments-main/pygments/styles/solarized.py +134 -0
- data/vendor/pygments-main/pygments/styles/stata_dark.py +41 -0
- data/vendor/pygments-main/pygments/styles/{stata.py → stata_light.py} +14 -15
- data/vendor/pygments-main/pygments/styles/tango.py +1 -1
- data/vendor/pygments-main/pygments/styles/trac.py +1 -1
- data/vendor/pygments-main/pygments/styles/vim.py +1 -1
- data/vendor/pygments-main/pygments/styles/vs.py +1 -1
- data/vendor/pygments-main/pygments/styles/xcode.py +1 -1
- data/vendor/pygments-main/pygments/token.py +1 -1
- data/vendor/pygments-main/pygments/unistring.py +47 -108
- data/vendor/pygments-main/pygments/util.py +15 -92
- metadata +69 -136
- data/CHANGELOG.md +0 -111
- data/README.md +0 -121
- data/circle.yml +0 -20
- data/test/test_data.py +0 -514
- data/test/test_data_generated +0 -2582
- data/vendor/custom_lexers/github.py +0 -565
- data/vendor/pygments-main/CHANGES +0 -1186
- data/vendor/pygments-main/MANIFEST.in +0 -6
- data/vendor/pygments-main/Makefile +0 -65
- data/vendor/pygments-main/README.rst +0 -39
- data/vendor/pygments-main/REVISION +0 -1
- data/vendor/pygments-main/TODO +0 -12
- data/vendor/pygments-main/doc/Makefile +0 -153
- data/vendor/pygments-main/doc/_static/favicon.ico +0 -0
- data/vendor/pygments-main/doc/_static/logo_new.png +0 -0
- data/vendor/pygments-main/doc/_static/logo_only.png +0 -0
- data/vendor/pygments-main/doc/_templates/docssidebar.html +0 -3
- data/vendor/pygments-main/doc/_templates/indexsidebar.html +0 -25
- data/vendor/pygments-main/doc/_themes/pygments14/layout.html +0 -98
- data/vendor/pygments-main/doc/_themes/pygments14/static/bodybg.png +0 -0
- data/vendor/pygments-main/doc/_themes/pygments14/static/docbg.png +0 -0
- data/vendor/pygments-main/doc/_themes/pygments14/static/listitem.png +0 -0
- data/vendor/pygments-main/doc/_themes/pygments14/static/logo.png +0 -0
- data/vendor/pygments-main/doc/_themes/pygments14/static/pocoo.png +0 -0
- data/vendor/pygments-main/doc/_themes/pygments14/static/pygments14.css_t +0 -401
- data/vendor/pygments-main/doc/_themes/pygments14/theme.conf +0 -15
- data/vendor/pygments-main/doc/conf.py +0 -241
- data/vendor/pygments-main/doc/docs/api.rst +0 -354
- data/vendor/pygments-main/doc/docs/authors.rst +0 -4
- data/vendor/pygments-main/doc/docs/changelog.rst +0 -1
- data/vendor/pygments-main/doc/docs/cmdline.rst +0 -166
- data/vendor/pygments-main/doc/docs/filterdevelopment.rst +0 -71
- data/vendor/pygments-main/doc/docs/filters.rst +0 -41
- data/vendor/pygments-main/doc/docs/formatterdevelopment.rst +0 -169
- data/vendor/pygments-main/doc/docs/formatters.rst +0 -48
- data/vendor/pygments-main/doc/docs/index.rst +0 -66
- data/vendor/pygments-main/doc/docs/integrate.rst +0 -40
- data/vendor/pygments-main/doc/docs/java.rst +0 -70
- data/vendor/pygments-main/doc/docs/lexerdevelopment.rst +0 -728
- data/vendor/pygments-main/doc/docs/lexers.rst +0 -69
- data/vendor/pygments-main/doc/docs/moinmoin.rst +0 -39
- data/vendor/pygments-main/doc/docs/plugins.rst +0 -93
- data/vendor/pygments-main/doc/docs/quickstart.rst +0 -205
- data/vendor/pygments-main/doc/docs/rstdirective.rst +0 -22
- data/vendor/pygments-main/doc/docs/styles.rst +0 -201
- data/vendor/pygments-main/doc/docs/tokens.rst +0 -372
- data/vendor/pygments-main/doc/docs/unicode.rst +0 -58
- data/vendor/pygments-main/doc/download.rst +0 -41
- data/vendor/pygments-main/doc/faq.rst +0 -139
- data/vendor/pygments-main/doc/index.rst +0 -54
- data/vendor/pygments-main/doc/languages.rst +0 -154
- data/vendor/pygments-main/doc/make.bat +0 -190
- data/vendor/pygments-main/doc/pygmentize.1 +0 -94
- data/vendor/pygments-main/external/autopygmentize +0 -101
- data/vendor/pygments-main/external/lasso-builtins-generator-9.lasso +0 -162
- data/vendor/pygments-main/external/markdown-processor.py +0 -67
- data/vendor/pygments-main/external/moin-parser.py +0 -112
- data/vendor/pygments-main/external/pygments.bashcomp +0 -38
- data/vendor/pygments-main/external/rst-directive.py +0 -82
- data/vendor/pygments-main/pygmentize +0 -8
- data/vendor/pygments-main/requirements.txt +0 -5
- data/vendor/pygments-main/scripts/check_sources.py +0 -211
- data/vendor/pygments-main/scripts/debug_lexer.py +0 -246
- data/vendor/pygments-main/scripts/detect_missing_analyse_text.py +0 -33
- data/vendor/pygments-main/scripts/epydoc.css +0 -280
- data/vendor/pygments-main/scripts/get_vimkw.py +0 -74
- data/vendor/pygments-main/scripts/pylintrc +0 -301
- data/vendor/pygments-main/scripts/vim2pygments.py +0 -935
- data/vendor/pygments-main/setup.cfg +0 -10
- data/vendor/pygments-main/setup.py +0 -77
- data/vendor/pygments-main/tox.ini +0 -7
- data/vendor/simplejson/.gitignore +0 -10
- data/vendor/simplejson/.travis.yml +0 -5
- data/vendor/simplejson/CHANGES.txt +0 -291
- data/vendor/simplejson/LICENSE.txt +0 -19
- data/vendor/simplejson/MANIFEST.in +0 -5
- data/vendor/simplejson/README.rst +0 -19
- data/vendor/simplejson/conf.py +0 -179
- data/vendor/simplejson/index.rst +0 -628
- data/vendor/simplejson/scripts/make_docs.py +0 -18
- data/vendor/simplejson/setup.py +0 -104
- data/vendor/simplejson/simplejson/__init__.py +0 -510
- data/vendor/simplejson/simplejson/_speedups.c +0 -2745
- data/vendor/simplejson/simplejson/decoder.py +0 -425
- data/vendor/simplejson/simplejson/encoder.py +0 -567
- data/vendor/simplejson/simplejson/ordered_dict.py +0 -119
- data/vendor/simplejson/simplejson/scanner.py +0 -77
- data/vendor/simplejson/simplejson/tests/__init__.py +0 -67
- data/vendor/simplejson/simplejson/tests/test_bigint_as_string.py +0 -55
- data/vendor/simplejson/simplejson/tests/test_check_circular.py +0 -30
- data/vendor/simplejson/simplejson/tests/test_decimal.py +0 -66
- data/vendor/simplejson/simplejson/tests/test_decode.py +0 -83
- data/vendor/simplejson/simplejson/tests/test_default.py +0 -9
- data/vendor/simplejson/simplejson/tests/test_dump.py +0 -67
- data/vendor/simplejson/simplejson/tests/test_encode_basestring_ascii.py +0 -46
- data/vendor/simplejson/simplejson/tests/test_encode_for_html.py +0 -32
- data/vendor/simplejson/simplejson/tests/test_errors.py +0 -34
- data/vendor/simplejson/simplejson/tests/test_fail.py +0 -91
- data/vendor/simplejson/simplejson/tests/test_float.py +0 -19
- data/vendor/simplejson/simplejson/tests/test_indent.py +0 -86
- data/vendor/simplejson/simplejson/tests/test_item_sort_key.py +0 -20
- data/vendor/simplejson/simplejson/tests/test_namedtuple.py +0 -121
- data/vendor/simplejson/simplejson/tests/test_pass1.py +0 -76
- data/vendor/simplejson/simplejson/tests/test_pass2.py +0 -14
- data/vendor/simplejson/simplejson/tests/test_pass3.py +0 -20
- data/vendor/simplejson/simplejson/tests/test_recursion.py +0 -67
- data/vendor/simplejson/simplejson/tests/test_scanstring.py +0 -117
- data/vendor/simplejson/simplejson/tests/test_separators.py +0 -42
- data/vendor/simplejson/simplejson/tests/test_speedups.py +0 -20
- data/vendor/simplejson/simplejson/tests/test_tuple.py +0 -49
- data/vendor/simplejson/simplejson/tests/test_unicode.py +0 -109
- data/vendor/simplejson/simplejson/tool.py +0 -39
@@ -1,119 +0,0 @@
|
|
1
|
-
"""Drop-in replacement for collections.OrderedDict by Raymond Hettinger
|
2
|
-
|
3
|
-
http://code.activestate.com/recipes/576693/
|
4
|
-
|
5
|
-
"""
|
6
|
-
from UserDict import DictMixin
|
7
|
-
|
8
|
-
# Modified from original to support Python 2.4, see
|
9
|
-
# http://code.google.com/p/simplejson/issues/detail?id=53
|
10
|
-
try:
|
11
|
-
all
|
12
|
-
except NameError:
|
13
|
-
def all(seq):
|
14
|
-
for elem in seq:
|
15
|
-
if not elem:
|
16
|
-
return False
|
17
|
-
return True
|
18
|
-
|
19
|
-
class OrderedDict(dict, DictMixin):
|
20
|
-
|
21
|
-
def __init__(self, *args, **kwds):
|
22
|
-
if len(args) > 1:
|
23
|
-
raise TypeError('expected at most 1 arguments, got %d' % len(args))
|
24
|
-
try:
|
25
|
-
self.__end
|
26
|
-
except AttributeError:
|
27
|
-
self.clear()
|
28
|
-
self.update(*args, **kwds)
|
29
|
-
|
30
|
-
def clear(self):
|
31
|
-
self.__end = end = []
|
32
|
-
end += [None, end, end] # sentinel node for doubly linked list
|
33
|
-
self.__map = {} # key --> [key, prev, next]
|
34
|
-
dict.clear(self)
|
35
|
-
|
36
|
-
def __setitem__(self, key, value):
|
37
|
-
if key not in self:
|
38
|
-
end = self.__end
|
39
|
-
curr = end[1]
|
40
|
-
curr[2] = end[1] = self.__map[key] = [key, curr, end]
|
41
|
-
dict.__setitem__(self, key, value)
|
42
|
-
|
43
|
-
def __delitem__(self, key):
|
44
|
-
dict.__delitem__(self, key)
|
45
|
-
key, prev, next = self.__map.pop(key)
|
46
|
-
prev[2] = next
|
47
|
-
next[1] = prev
|
48
|
-
|
49
|
-
def __iter__(self):
|
50
|
-
end = self.__end
|
51
|
-
curr = end[2]
|
52
|
-
while curr is not end:
|
53
|
-
yield curr[0]
|
54
|
-
curr = curr[2]
|
55
|
-
|
56
|
-
def __reversed__(self):
|
57
|
-
end = self.__end
|
58
|
-
curr = end[1]
|
59
|
-
while curr is not end:
|
60
|
-
yield curr[0]
|
61
|
-
curr = curr[1]
|
62
|
-
|
63
|
-
def popitem(self, last=True):
|
64
|
-
if not self:
|
65
|
-
raise KeyError('dictionary is empty')
|
66
|
-
# Modified from original to support Python 2.4, see
|
67
|
-
# http://code.google.com/p/simplejson/issues/detail?id=53
|
68
|
-
if last:
|
69
|
-
key = reversed(self).next()
|
70
|
-
else:
|
71
|
-
key = iter(self).next()
|
72
|
-
value = self.pop(key)
|
73
|
-
return key, value
|
74
|
-
|
75
|
-
def __reduce__(self):
|
76
|
-
items = [[k, self[k]] for k in self]
|
77
|
-
tmp = self.__map, self.__end
|
78
|
-
del self.__map, self.__end
|
79
|
-
inst_dict = vars(self).copy()
|
80
|
-
self.__map, self.__end = tmp
|
81
|
-
if inst_dict:
|
82
|
-
return (self.__class__, (items,), inst_dict)
|
83
|
-
return self.__class__, (items,)
|
84
|
-
|
85
|
-
def keys(self):
|
86
|
-
return list(self)
|
87
|
-
|
88
|
-
setdefault = DictMixin.setdefault
|
89
|
-
update = DictMixin.update
|
90
|
-
pop = DictMixin.pop
|
91
|
-
values = DictMixin.values
|
92
|
-
items = DictMixin.items
|
93
|
-
iterkeys = DictMixin.iterkeys
|
94
|
-
itervalues = DictMixin.itervalues
|
95
|
-
iteritems = DictMixin.iteritems
|
96
|
-
|
97
|
-
def __repr__(self):
|
98
|
-
if not self:
|
99
|
-
return '%s()' % (self.__class__.__name__,)
|
100
|
-
return '%s(%r)' % (self.__class__.__name__, self.items())
|
101
|
-
|
102
|
-
def copy(self):
|
103
|
-
return self.__class__(self)
|
104
|
-
|
105
|
-
@classmethod
|
106
|
-
def fromkeys(cls, iterable, value=None):
|
107
|
-
d = cls()
|
108
|
-
for key in iterable:
|
109
|
-
d[key] = value
|
110
|
-
return d
|
111
|
-
|
112
|
-
def __eq__(self, other):
|
113
|
-
if isinstance(other, OrderedDict):
|
114
|
-
return len(self)==len(other) and \
|
115
|
-
all(p==q for p, q in zip(self.items(), other.items()))
|
116
|
-
return dict.__eq__(self, other)
|
117
|
-
|
118
|
-
def __ne__(self, other):
|
119
|
-
return not self == other
|
@@ -1,77 +0,0 @@
|
|
1
|
-
"""JSON token scanner
|
2
|
-
"""
|
3
|
-
import re
|
4
|
-
def _import_c_make_scanner():
|
5
|
-
try:
|
6
|
-
from simplejson._speedups import make_scanner
|
7
|
-
return make_scanner
|
8
|
-
except ImportError:
|
9
|
-
return None
|
10
|
-
c_make_scanner = _import_c_make_scanner()
|
11
|
-
|
12
|
-
__all__ = ['make_scanner']
|
13
|
-
|
14
|
-
NUMBER_RE = re.compile(
|
15
|
-
r'(-?(?:0|[1-9]\d*))(\.\d+)?([eE][-+]?\d+)?',
|
16
|
-
(re.VERBOSE | re.MULTILINE | re.DOTALL))
|
17
|
-
|
18
|
-
def py_make_scanner(context):
|
19
|
-
parse_object = context.parse_object
|
20
|
-
parse_array = context.parse_array
|
21
|
-
parse_string = context.parse_string
|
22
|
-
match_number = NUMBER_RE.match
|
23
|
-
encoding = context.encoding
|
24
|
-
strict = context.strict
|
25
|
-
parse_float = context.parse_float
|
26
|
-
parse_int = context.parse_int
|
27
|
-
parse_constant = context.parse_constant
|
28
|
-
object_hook = context.object_hook
|
29
|
-
object_pairs_hook = context.object_pairs_hook
|
30
|
-
memo = context.memo
|
31
|
-
|
32
|
-
def _scan_once(string, idx):
|
33
|
-
try:
|
34
|
-
nextchar = string[idx]
|
35
|
-
except IndexError:
|
36
|
-
raise StopIteration
|
37
|
-
|
38
|
-
if nextchar == '"':
|
39
|
-
return parse_string(string, idx + 1, encoding, strict)
|
40
|
-
elif nextchar == '{':
|
41
|
-
return parse_object((string, idx + 1), encoding, strict,
|
42
|
-
_scan_once, object_hook, object_pairs_hook, memo)
|
43
|
-
elif nextchar == '[':
|
44
|
-
return parse_array((string, idx + 1), _scan_once)
|
45
|
-
elif nextchar == 'n' and string[idx:idx + 4] == 'null':
|
46
|
-
return None, idx + 4
|
47
|
-
elif nextchar == 't' and string[idx:idx + 4] == 'true':
|
48
|
-
return True, idx + 4
|
49
|
-
elif nextchar == 'f' and string[idx:idx + 5] == 'false':
|
50
|
-
return False, idx + 5
|
51
|
-
|
52
|
-
m = match_number(string, idx)
|
53
|
-
if m is not None:
|
54
|
-
integer, frac, exp = m.groups()
|
55
|
-
if frac or exp:
|
56
|
-
res = parse_float(integer + (frac or '') + (exp or ''))
|
57
|
-
else:
|
58
|
-
res = parse_int(integer)
|
59
|
-
return res, m.end()
|
60
|
-
elif nextchar == 'N' and string[idx:idx + 3] == 'NaN':
|
61
|
-
return parse_constant('NaN'), idx + 3
|
62
|
-
elif nextchar == 'I' and string[idx:idx + 8] == 'Infinity':
|
63
|
-
return parse_constant('Infinity'), idx + 8
|
64
|
-
elif nextchar == '-' and string[idx:idx + 9] == '-Infinity':
|
65
|
-
return parse_constant('-Infinity'), idx + 9
|
66
|
-
else:
|
67
|
-
raise StopIteration
|
68
|
-
|
69
|
-
def scan_once(string, idx):
|
70
|
-
try:
|
71
|
-
return _scan_once(string, idx)
|
72
|
-
finally:
|
73
|
-
memo.clear()
|
74
|
-
|
75
|
-
return scan_once
|
76
|
-
|
77
|
-
make_scanner = c_make_scanner or py_make_scanner
|
@@ -1,67 +0,0 @@
|
|
1
|
-
import unittest
|
2
|
-
import doctest
|
3
|
-
|
4
|
-
|
5
|
-
class OptionalExtensionTestSuite(unittest.TestSuite):
|
6
|
-
def run(self, result):
|
7
|
-
import simplejson
|
8
|
-
run = unittest.TestSuite.run
|
9
|
-
run(self, result)
|
10
|
-
simplejson._toggle_speedups(False)
|
11
|
-
run(self, result)
|
12
|
-
simplejson._toggle_speedups(True)
|
13
|
-
return result
|
14
|
-
|
15
|
-
|
16
|
-
def additional_tests(suite=None):
|
17
|
-
import simplejson
|
18
|
-
import simplejson.encoder
|
19
|
-
import simplejson.decoder
|
20
|
-
if suite is None:
|
21
|
-
suite = unittest.TestSuite()
|
22
|
-
for mod in (simplejson, simplejson.encoder, simplejson.decoder):
|
23
|
-
suite.addTest(doctest.DocTestSuite(mod))
|
24
|
-
suite.addTest(doctest.DocFileSuite('../../index.rst'))
|
25
|
-
return suite
|
26
|
-
|
27
|
-
|
28
|
-
def all_tests_suite():
|
29
|
-
suite = unittest.TestLoader().loadTestsFromNames([
|
30
|
-
'simplejson.tests.test_bigint_as_string',
|
31
|
-
'simplejson.tests.test_check_circular',
|
32
|
-
'simplejson.tests.test_decode',
|
33
|
-
'simplejson.tests.test_default',
|
34
|
-
'simplejson.tests.test_dump',
|
35
|
-
'simplejson.tests.test_encode_basestring_ascii',
|
36
|
-
'simplejson.tests.test_encode_for_html',
|
37
|
-
'simplejson.tests.test_errors',
|
38
|
-
'simplejson.tests.test_fail',
|
39
|
-
'simplejson.tests.test_float',
|
40
|
-
'simplejson.tests.test_indent',
|
41
|
-
'simplejson.tests.test_pass1',
|
42
|
-
'simplejson.tests.test_pass2',
|
43
|
-
'simplejson.tests.test_pass3',
|
44
|
-
'simplejson.tests.test_recursion',
|
45
|
-
'simplejson.tests.test_scanstring',
|
46
|
-
'simplejson.tests.test_separators',
|
47
|
-
'simplejson.tests.test_speedups',
|
48
|
-
'simplejson.tests.test_unicode',
|
49
|
-
'simplejson.tests.test_decimal',
|
50
|
-
'simplejson.tests.test_tuple',
|
51
|
-
'simplejson.tests.test_namedtuple',
|
52
|
-
])
|
53
|
-
suite = additional_tests(suite)
|
54
|
-
return OptionalExtensionTestSuite([suite])
|
55
|
-
|
56
|
-
|
57
|
-
def main():
|
58
|
-
runner = unittest.TextTestRunner()
|
59
|
-
suite = all_tests_suite()
|
60
|
-
raise SystemExit(not runner.run(suite).wasSuccessful())
|
61
|
-
|
62
|
-
|
63
|
-
if __name__ == '__main__':
|
64
|
-
import os
|
65
|
-
import sys
|
66
|
-
sys.path.insert(0, os.path.dirname(os.path.dirname(os.path.dirname(os.path.abspath(__file__)))))
|
67
|
-
main()
|
@@ -1,55 +0,0 @@
|
|
1
|
-
from unittest import TestCase
|
2
|
-
|
3
|
-
import simplejson as json
|
4
|
-
|
5
|
-
class TestBigintAsString(TestCase):
|
6
|
-
values = [(200, 200),
|
7
|
-
((2 ** 53) - 1, 9007199254740991),
|
8
|
-
((2 ** 53), '9007199254740992'),
|
9
|
-
((2 ** 53) + 1, '9007199254740993'),
|
10
|
-
(-100, -100),
|
11
|
-
((-2 ** 53), '-9007199254740992'),
|
12
|
-
((-2 ** 53) - 1, '-9007199254740993'),
|
13
|
-
((-2 ** 53) + 1, -9007199254740991)]
|
14
|
-
|
15
|
-
def test_ints(self):
|
16
|
-
for val, expect in self.values:
|
17
|
-
self.assertEquals(
|
18
|
-
val,
|
19
|
-
json.loads(json.dumps(val)))
|
20
|
-
self.assertEquals(
|
21
|
-
expect,
|
22
|
-
json.loads(json.dumps(val, bigint_as_string=True)))
|
23
|
-
|
24
|
-
def test_lists(self):
|
25
|
-
for val, expect in self.values:
|
26
|
-
val = [val, val]
|
27
|
-
expect = [expect, expect]
|
28
|
-
self.assertEquals(
|
29
|
-
val,
|
30
|
-
json.loads(json.dumps(val)))
|
31
|
-
self.assertEquals(
|
32
|
-
expect,
|
33
|
-
json.loads(json.dumps(val, bigint_as_string=True)))
|
34
|
-
|
35
|
-
def test_dicts(self):
|
36
|
-
for val, expect in self.values:
|
37
|
-
val = {'k': val}
|
38
|
-
expect = {'k': expect}
|
39
|
-
self.assertEquals(
|
40
|
-
val,
|
41
|
-
json.loads(json.dumps(val)))
|
42
|
-
self.assertEquals(
|
43
|
-
expect,
|
44
|
-
json.loads(json.dumps(val, bigint_as_string=True)))
|
45
|
-
|
46
|
-
def test_dict_keys(self):
|
47
|
-
for val, _ in self.values:
|
48
|
-
expect = {str(val): 'value'}
|
49
|
-
val = {val: 'value'}
|
50
|
-
self.assertEquals(
|
51
|
-
expect,
|
52
|
-
json.loads(json.dumps(val)))
|
53
|
-
self.assertEquals(
|
54
|
-
expect,
|
55
|
-
json.loads(json.dumps(val, bigint_as_string=True)))
|
@@ -1,30 +0,0 @@
|
|
1
|
-
from unittest import TestCase
|
2
|
-
import simplejson as json
|
3
|
-
|
4
|
-
def default_iterable(obj):
|
5
|
-
return list(obj)
|
6
|
-
|
7
|
-
class TestCheckCircular(TestCase):
|
8
|
-
def test_circular_dict(self):
|
9
|
-
dct = {}
|
10
|
-
dct['a'] = dct
|
11
|
-
self.assertRaises(ValueError, json.dumps, dct)
|
12
|
-
|
13
|
-
def test_circular_list(self):
|
14
|
-
lst = []
|
15
|
-
lst.append(lst)
|
16
|
-
self.assertRaises(ValueError, json.dumps, lst)
|
17
|
-
|
18
|
-
def test_circular_composite(self):
|
19
|
-
dct2 = {}
|
20
|
-
dct2['a'] = []
|
21
|
-
dct2['a'].append(dct2)
|
22
|
-
self.assertRaises(ValueError, json.dumps, dct2)
|
23
|
-
|
24
|
-
def test_circular_default(self):
|
25
|
-
json.dumps([set()], default=default_iterable)
|
26
|
-
self.assertRaises(TypeError, json.dumps, [set()])
|
27
|
-
|
28
|
-
def test_circular_off_default(self):
|
29
|
-
json.dumps([set()], default=default_iterable, check_circular=False)
|
30
|
-
self.assertRaises(TypeError, json.dumps, [set()], check_circular=False)
|
@@ -1,66 +0,0 @@
|
|
1
|
-
import decimal
|
2
|
-
from decimal import Decimal
|
3
|
-
from unittest import TestCase
|
4
|
-
from StringIO import StringIO
|
5
|
-
|
6
|
-
import simplejson as json
|
7
|
-
|
8
|
-
class TestDecimal(TestCase):
|
9
|
-
NUMS = "1.0", "10.00", "1.1", "1234567890.1234567890", "500"
|
10
|
-
def dumps(self, obj, **kw):
|
11
|
-
sio = StringIO()
|
12
|
-
json.dump(obj, sio, **kw)
|
13
|
-
res = json.dumps(obj, **kw)
|
14
|
-
self.assertEquals(res, sio.getvalue())
|
15
|
-
return res
|
16
|
-
|
17
|
-
def loads(self, s, **kw):
|
18
|
-
sio = StringIO(s)
|
19
|
-
res = json.loads(s, **kw)
|
20
|
-
self.assertEquals(res, json.load(sio, **kw))
|
21
|
-
return res
|
22
|
-
|
23
|
-
def test_decimal_encode(self):
|
24
|
-
for d in map(Decimal, self.NUMS):
|
25
|
-
self.assertEquals(self.dumps(d, use_decimal=True), str(d))
|
26
|
-
|
27
|
-
def test_decimal_decode(self):
|
28
|
-
for s in self.NUMS:
|
29
|
-
self.assertEquals(self.loads(s, parse_float=Decimal), Decimal(s))
|
30
|
-
|
31
|
-
def test_decimal_roundtrip(self):
|
32
|
-
for d in map(Decimal, self.NUMS):
|
33
|
-
# The type might not be the same (int and Decimal) but they
|
34
|
-
# should still compare equal.
|
35
|
-
self.assertEquals(
|
36
|
-
self.loads(
|
37
|
-
self.dumps(d, use_decimal=True), parse_float=Decimal),
|
38
|
-
d)
|
39
|
-
self.assertEquals(
|
40
|
-
self.loads(
|
41
|
-
self.dumps([d], use_decimal=True), parse_float=Decimal),
|
42
|
-
[d])
|
43
|
-
|
44
|
-
def test_decimal_defaults(self):
|
45
|
-
d = Decimal('1.1')
|
46
|
-
# use_decimal=True is the default
|
47
|
-
self.assertRaises(TypeError, json.dumps, d, use_decimal=False)
|
48
|
-
self.assertEqual('1.1', json.dumps(d))
|
49
|
-
self.assertEqual('1.1', json.dumps(d, use_decimal=True))
|
50
|
-
self.assertRaises(TypeError, json.dump, d, StringIO(),
|
51
|
-
use_decimal=False)
|
52
|
-
sio = StringIO()
|
53
|
-
json.dump(d, sio)
|
54
|
-
self.assertEqual('1.1', sio.getvalue())
|
55
|
-
sio = StringIO()
|
56
|
-
json.dump(d, sio, use_decimal=True)
|
57
|
-
self.assertEqual('1.1', sio.getvalue())
|
58
|
-
|
59
|
-
def test_decimal_reload(self):
|
60
|
-
# Simulate a subinterpreter that reloads the Python modules but not
|
61
|
-
# the C code https://github.com/simplejson/simplejson/issues/34
|
62
|
-
global Decimal
|
63
|
-
Decimal = reload(decimal).Decimal
|
64
|
-
import simplejson.encoder
|
65
|
-
simplejson.encoder.Decimal = Decimal
|
66
|
-
self.test_decimal_roundtrip()
|
@@ -1,83 +0,0 @@
|
|
1
|
-
import decimal
|
2
|
-
from unittest import TestCase
|
3
|
-
from StringIO import StringIO
|
4
|
-
|
5
|
-
import simplejson as json
|
6
|
-
from simplejson import OrderedDict
|
7
|
-
|
8
|
-
class TestDecode(TestCase):
|
9
|
-
if not hasattr(TestCase, 'assertIs'):
|
10
|
-
def assertIs(self, a, b):
|
11
|
-
self.assertTrue(a is b, '%r is %r' % (a, b))
|
12
|
-
|
13
|
-
def test_decimal(self):
|
14
|
-
rval = json.loads('1.1', parse_float=decimal.Decimal)
|
15
|
-
self.assertTrue(isinstance(rval, decimal.Decimal))
|
16
|
-
self.assertEquals(rval, decimal.Decimal('1.1'))
|
17
|
-
|
18
|
-
def test_float(self):
|
19
|
-
rval = json.loads('1', parse_int=float)
|
20
|
-
self.assertTrue(isinstance(rval, float))
|
21
|
-
self.assertEquals(rval, 1.0)
|
22
|
-
|
23
|
-
def test_decoder_optimizations(self):
|
24
|
-
# Several optimizations were made that skip over calls to
|
25
|
-
# the whitespace regex, so this test is designed to try and
|
26
|
-
# exercise the uncommon cases. The array cases are already covered.
|
27
|
-
rval = json.loads('{ "key" : "value" , "k":"v" }')
|
28
|
-
self.assertEquals(rval, {"key":"value", "k":"v"})
|
29
|
-
|
30
|
-
def test_empty_objects(self):
|
31
|
-
s = '{}'
|
32
|
-
self.assertEqual(json.loads(s), eval(s))
|
33
|
-
s = '[]'
|
34
|
-
self.assertEqual(json.loads(s), eval(s))
|
35
|
-
s = '""'
|
36
|
-
self.assertEqual(json.loads(s), eval(s))
|
37
|
-
|
38
|
-
def test_object_pairs_hook(self):
|
39
|
-
s = '{"xkd":1, "kcw":2, "art":3, "hxm":4, "qrt":5, "pad":6, "hoy":7}'
|
40
|
-
p = [("xkd", 1), ("kcw", 2), ("art", 3), ("hxm", 4),
|
41
|
-
("qrt", 5), ("pad", 6), ("hoy", 7)]
|
42
|
-
self.assertEqual(json.loads(s), eval(s))
|
43
|
-
self.assertEqual(json.loads(s, object_pairs_hook=lambda x: x), p)
|
44
|
-
self.assertEqual(json.load(StringIO(s),
|
45
|
-
object_pairs_hook=lambda x: x), p)
|
46
|
-
od = json.loads(s, object_pairs_hook=OrderedDict)
|
47
|
-
self.assertEqual(od, OrderedDict(p))
|
48
|
-
self.assertEqual(type(od), OrderedDict)
|
49
|
-
# the object_pairs_hook takes priority over the object_hook
|
50
|
-
self.assertEqual(json.loads(s,
|
51
|
-
object_pairs_hook=OrderedDict,
|
52
|
-
object_hook=lambda x: None),
|
53
|
-
OrderedDict(p))
|
54
|
-
|
55
|
-
def check_keys_reuse(self, source, loads):
|
56
|
-
rval = loads(source)
|
57
|
-
(a, b), (c, d) = sorted(rval[0]), sorted(rval[1])
|
58
|
-
self.assertIs(a, c)
|
59
|
-
self.assertIs(b, d)
|
60
|
-
|
61
|
-
def test_keys_reuse_str(self):
|
62
|
-
s = u'[{"a_key": 1, "b_\xe9": 2}, {"a_key": 3, "b_\xe9": 4}]'.encode('utf8')
|
63
|
-
self.check_keys_reuse(s, json.loads)
|
64
|
-
|
65
|
-
def test_keys_reuse_unicode(self):
|
66
|
-
s = u'[{"a_key": 1, "b_\xe9": 2}, {"a_key": 3, "b_\xe9": 4}]'
|
67
|
-
self.check_keys_reuse(s, json.loads)
|
68
|
-
|
69
|
-
def test_empty_strings(self):
|
70
|
-
self.assertEqual(json.loads('""'), "")
|
71
|
-
self.assertEqual(json.loads(u'""'), u"")
|
72
|
-
self.assertEqual(json.loads('[""]'), [""])
|
73
|
-
self.assertEqual(json.loads(u'[""]'), [u""])
|
74
|
-
|
75
|
-
def test_raw_decode(self):
|
76
|
-
cls = json.decoder.JSONDecoder
|
77
|
-
self.assertEqual(
|
78
|
-
({'a': {}}, 9),
|
79
|
-
cls().raw_decode("{\"a\": {}}"))
|
80
|
-
# http://code.google.com/p/simplejson/issues/detail?id=85
|
81
|
-
self.assertEqual(
|
82
|
-
({'a': {}}, 9),
|
83
|
-
cls(object_pairs_hook=dict).raw_decode("{\"a\": {}}"))
|