diff options
author | Benjamin Peterson <benjamin@python.org> | 2008-12-12 02:02:24 (GMT) |
---|---|---|
committer | Benjamin Peterson <benjamin@python.org> | 2008-12-12 02:02:24 (GMT) |
commit | a5bbf200172d52714a64f9294d86c14bd8eda501 (patch) | |
tree | 569e1c182105ecf44227edfa5bd0169a6ae3e6e8 | |
parent | d94726728305dda47726f0b8d9ef9aa4979f6275 (diff) | |
download | cpython-a5bbf200172d52714a64f9294d86c14bd8eda501.zip cpython-a5bbf200172d52714a64f9294d86c14bd8eda501.tar.gz cpython-a5bbf200172d52714a64f9294d86c14bd8eda501.tar.bz2 |
revert r67713. it causes build problems
-rw-r--r-- | Lib/linecache.py | 24 |
1 files changed, 20 insertions, 4 deletions
diff --git a/Lib/linecache.py b/Lib/linecache.py index 7f249a0..50a0c1b 100644 --- a/Lib/linecache.py +++ b/Lib/linecache.py @@ -7,7 +7,7 @@ that name. import sys import os -import tokenize +import re __all__ = ["getline", "clearcache", "checkcache"] @@ -121,11 +121,27 @@ def updatecache(filename, module_globals=None): pass else: # No luck +## print '*** Cannot stat', filename, ':', msg return [] - with open(fullname, 'rb') as fp: - coding, line = tokenize.detect_encoding(fp.readline) - with open(fullname, 'r', encoding=coding) as fp: +## print("Refreshing cache for %s..." % fullname) + try: + fp = open(fullname, 'rU') lines = fp.readlines() + fp.close() + except Exception as msg: +## print '*** Cannot open', fullname, ':', msg + return [] + coding = "utf-8" + for line in lines[:2]: + m = re.search(r"coding[:=]\s*([-\w.]+)", line) + if m: + coding = m.group(1) + break + try: + lines = [line if isinstance(line, str) else str(line, coding) + for line in lines] + except: + pass # Hope for the best size, mtime = stat.st_size, stat.st_mtime cache[filename] = size, mtime, lines, fullname return lines |