summaryrefslogtreecommitdiffstats
path: root/Lib/json
diff options
context:
space:
mode:
authorEzio Melotti <ezio.melotti@gmail.com>2012-11-29 00:15:18 (GMT)
committerEzio Melotti <ezio.melotti@gmail.com>2012-11-29 00:15:18 (GMT)
commit057bcb4c6c7eef93066002db7ab486f12d50ccee (patch)
tree6476f03b22dec615e1bb2b3c9364ddeac8039b16 /Lib/json
parentd654dedbbb1116bfed989aafd2ee7a004828546b (diff)
downloadcpython-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.py20
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__':