summaryrefslogtreecommitdiffstats
path: root/Lib/linecache.py
diff options
context:
space:
mode:
authorBenjamin Peterson <benjamin@python.org>2008-12-12 02:02:24 (GMT)
committerBenjamin Peterson <benjamin@python.org>2008-12-12 02:02:24 (GMT)
commita5bbf200172d52714a64f9294d86c14bd8eda501 (patch)
tree569e1c182105ecf44227edfa5bd0169a6ae3e6e8 /Lib/linecache.py
parentd94726728305dda47726f0b8d9ef9aa4979f6275 (diff)
downloadcpython-a5bbf200172d52714a64f9294d86c14bd8eda501.zip
cpython-a5bbf200172d52714a64f9294d86c14bd8eda501.tar.gz
cpython-a5bbf200172d52714a64f9294d86c14bd8eda501.tar.bz2
revert r67713. it causes build problems
Diffstat (limited to 'Lib/linecache.py')
-rw-r--r--Lib/linecache.py24
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