diff options
author | Ezio Melotti <ezio.melotti@gmail.com> | 2012-11-29 00:15:18 (GMT) |
---|---|---|
committer | Ezio Melotti <ezio.melotti@gmail.com> | 2012-11-29 00:15:18 (GMT) |
commit | 057bcb4c6c7eef93066002db7ab486f12d50ccee (patch) | |
tree | 6476f03b22dec615e1bb2b3c9364ddeac8039b16 /Lib/json | |
parent | d654dedbbb1116bfed989aafd2ee7a004828546b (diff) | |
download | cpython-057bcb4c6c7eef93066002db7ab486f12d50ccee.zip cpython-057bcb4c6c7eef93066002db7ab486f12d50ccee.tar.gz cpython-057bcb4c6c7eef93066002db7ab486f12d50ccee.tar.bz2 |
#16549: Make json.tool work again on Python 3 and add tests. Initial patch by Berker Peksag and Serhiy Storchaka.
Diffstat (limited to 'Lib/json')
-rw-r--r-- | Lib/json/tool.py | 20 |
1 files changed, 11 insertions, 9 deletions
diff --git a/Lib/json/tool.py b/Lib/json/tool.py index 1adea31..9ab6d65 100644 --- a/Lib/json/tool.py +++ b/Lib/json/tool.py @@ -18,19 +18,21 @@ def main(): infile = sys.stdin outfile = sys.stdout elif len(sys.argv) == 2: - infile = open(sys.argv[1], 'rb') + infile = open(sys.argv[1], 'r') outfile = sys.stdout elif len(sys.argv) == 3: - infile = open(sys.argv[1], 'rb') - outfile = open(sys.argv[2], 'wb') + infile = open(sys.argv[1], 'r') + outfile = open(sys.argv[2], 'w') else: raise SystemExit(sys.argv[0] + " [infile [outfile]]") - try: - obj = json.load(infile) - except ValueError as e: - raise SystemExit(e) - json.dump(obj, outfile, sort_keys=True, indent=4) - outfile.write('\n') + with infile: + try: + obj = json.load(infile) + except ValueError as e: + raise SystemExit(e) + with outfile: + json.dump(obj, outfile, sort_keys=True, indent=4) + outfile.write('\n') if __name__ == '__main__': |