diff options
author | Benjamin Peterson <benjamin@python.org> | 2010-10-30 23:51:34 (GMT) |
---|---|---|
committer | Benjamin Peterson <benjamin@python.org> | 2010-10-30 23:51:34 (GMT) |
commit | b2fda239225413ae5658f2409ac4d7922b3c7e7c (patch) | |
tree | 6b915c1c088d17ee589cfbfbc789489e848eb0b2 | |
parent | bbb0412ad179b4a94d03ce592a5bc1d40724998e (diff) | |
download | cpython-b2fda239225413ae5658f2409ac4d7922b3c7e7c.zip cpython-b2fda239225413ae5658f2409ac4d7922b3c7e7c.tar.gz cpython-b2fda239225413ae5658f2409ac4d7922b3c7e7c.tar.bz2 |
close files correctly
-rw-r--r-- | Lib/trace.py | 23 |
1 files changed, 12 insertions, 11 deletions
diff --git a/Lib/trace.py b/Lib/trace.py index fa24fc1..ec45d81 100644 --- a/Lib/trace.py +++ b/Lib/trace.py @@ -404,16 +404,16 @@ def find_strings(filename, encoding=None): # If the first token is a string, then it's the module docstring. # Add this special case so that the test in the loop passes. prev_ttype = token.INDENT - f = open(filename, encoding=encoding) - for ttype, tstr, start, end, line in tokenize.generate_tokens(f.readline): - if ttype == token.STRING: - if prev_ttype == token.INDENT: - sline, scol = start - eline, ecol = end - for i in range(sline, eline + 1): - d[i] = 1 - prev_ttype = ttype - f.close() + with open(filename, encoding=encoding) as f: + tok = tokenize.generate_tokens(f.readline) + for ttype, tstr, start, end, line in tok: + if ttype == token.STRING: + if prev_ttype == token.INDENT: + sline, scol = start + eline, ecol = end + for i in range(sline, eline + 1): + d[i] = 1 + prev_ttype = ttype return d def find_executable_linenos(filename): @@ -421,7 +421,8 @@ def find_executable_linenos(filename): try: with io.FileIO(filename, 'r') as file: encoding, lines = tokenize.detect_encoding(file.readline) - prog = open(filename, "r", encoding=encoding).read() + with open(filename, "r", encoding=encoding) as f: + prog = f.read() except IOError as err: print(("Not printing coverage data for %r: %s" % (filename, err)), file=sys.stderr) |