mirror of
https://github.com/python/cpython.git
synced 2025-09-26 18:29:57 +00:00
Merged revisions 81428-81429,81432-81433,81437 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk ........ r81428 | benjamin.peterson | 2010-05-21 16:16:12 -0500 (Fri, 21 May 2010) | 1 line use addCleanup ........ r81429 | benjamin.peterson | 2010-05-21 16:17:22 -0500 (Fri, 21 May 2010) | 1 line fix name ........ r81432 | benjamin.peterson | 2010-05-21 16:31:24 -0500 (Fri, 21 May 2010) | 1 line ensure the last line has a trailing newline #8782 ........ r81433 | benjamin.peterson | 2010-05-21 16:32:49 -0500 (Fri, 21 May 2010) | 1 line remove debugging rubish ........ r81437 | benjamin.peterson | 2010-05-21 16:35:44 -0500 (Fri, 21 May 2010) | 1 line simplify and modernize updatecache() ........
This commit is contained in:
parent
d25a5da9f2
commit
aada7b8f78
3 changed files with 57 additions and 42 deletions
|
@ -73,13 +73,13 @@ def updatecache(filename, module_globals=None):
|
||||||
|
|
||||||
if filename in cache:
|
if filename in cache:
|
||||||
del cache[filename]
|
del cache[filename]
|
||||||
if not filename or filename[0] + filename[-1] == '<>':
|
if not filename or (filename.startswith('<') and filename.endswith('>')):
|
||||||
return []
|
return []
|
||||||
|
|
||||||
fullname = filename
|
fullname = filename
|
||||||
try:
|
try:
|
||||||
stat = os.stat(fullname)
|
stat = os.stat(fullname)
|
||||||
except os.error as msg:
|
except OSError:
|
||||||
basename = filename
|
basename = filename
|
||||||
|
|
||||||
# Try for a __loader__, if available
|
# Try for a __loader__, if available
|
||||||
|
@ -114,20 +114,23 @@ def updatecache(filename, module_globals=None):
|
||||||
fullname = os.path.join(dirname, basename)
|
fullname = os.path.join(dirname, basename)
|
||||||
except (TypeError, AttributeError):
|
except (TypeError, AttributeError):
|
||||||
# Not sufficiently string-like to do anything useful with.
|
# Not sufficiently string-like to do anything useful with.
|
||||||
pass
|
continue
|
||||||
else:
|
|
||||||
try:
|
try:
|
||||||
stat = os.stat(fullname)
|
stat = os.stat(fullname)
|
||||||
break
|
break
|
||||||
except os.error:
|
except os.error:
|
||||||
pass
|
pass
|
||||||
else:
|
else:
|
||||||
# No luck
|
|
||||||
return []
|
return []
|
||||||
|
try:
|
||||||
with open(fullname, 'rb') as fp:
|
with open(fullname, 'rb') as fp:
|
||||||
coding, line = tokenize.detect_encoding(fp.readline)
|
coding, line = tokenize.detect_encoding(fp.readline)
|
||||||
with open(fullname, 'r', encoding=coding) as fp:
|
with open(fullname, 'r', encoding=coding) as fp:
|
||||||
lines = fp.readlines()
|
lines = fp.readlines()
|
||||||
|
except IOError:
|
||||||
|
pass
|
||||||
|
if lines and not lines[-1].endswith('\n'):
|
||||||
|
lines[-1] += '\n'
|
||||||
size, mtime = stat.st_size, stat.st_mtime
|
size, mtime = stat.st_size, stat.st_mtime
|
||||||
cache[filename] = size, mtime, lines, fullname
|
cache[filename] = size, mtime, lines, fullname
|
||||||
return lines
|
return lines
|
||||||
|
|
|
@ -31,6 +31,11 @@ a = f()
|
||||||
|
|
||||||
'''
|
'''
|
||||||
|
|
||||||
|
SOURCE_3 = '''
|
||||||
|
def f():
|
||||||
|
return 3''' # No ending newline
|
||||||
|
|
||||||
|
|
||||||
class LineCacheTests(unittest.TestCase):
|
class LineCacheTests(unittest.TestCase):
|
||||||
|
|
||||||
def test_getline(self):
|
def test_getline(self):
|
||||||
|
@ -63,6 +68,13 @@ class LineCacheTests(unittest.TestCase):
|
||||||
empty = linecache.getlines('a/b/c/__init__.py')
|
empty = linecache.getlines('a/b/c/__init__.py')
|
||||||
self.assertEquals(empty, [])
|
self.assertEquals(empty, [])
|
||||||
|
|
||||||
|
def test_no_ending_newline(self):
|
||||||
|
self.addCleanup(support.unlink, support.TESTFN)
|
||||||
|
with open(support.TESTFN, "w") as fp:
|
||||||
|
fp.write(SOURCE_3)
|
||||||
|
lines = linecache.getlines(support.TESTFN)
|
||||||
|
self.assertEqual(lines, ["\n", "def f():\n", " return 3\n"])
|
||||||
|
|
||||||
def test_clearcache(self):
|
def test_clearcache(self):
|
||||||
cached = []
|
cached = []
|
||||||
for entry in TESTS:
|
for entry in TESTS:
|
||||||
|
@ -81,9 +93,9 @@ class LineCacheTests(unittest.TestCase):
|
||||||
|
|
||||||
def test_checkcache(self):
|
def test_checkcache(self):
|
||||||
getline = linecache.getline
|
getline = linecache.getline
|
||||||
try:
|
|
||||||
# Create a source file and cache its contents
|
# Create a source file and cache its contents
|
||||||
source_name = support.TESTFN + '.py'
|
source_name = support.TESTFN + '.py'
|
||||||
|
self.addCleanup(support.unlink, source_name)
|
||||||
with open(source_name, 'w') as source:
|
with open(source_name, 'w') as source:
|
||||||
source.write(SOURCE_1)
|
source.write(SOURCE_1)
|
||||||
getline(source_name, 1)
|
getline(source_name, 1)
|
||||||
|
@ -112,9 +124,6 @@ class LineCacheTests(unittest.TestCase):
|
||||||
self.assertEquals(line, getline(source_name, index + 1))
|
self.assertEquals(line, getline(source_name, index + 1))
|
||||||
source_list.append(line)
|
source_list.append(line)
|
||||||
|
|
||||||
finally:
|
|
||||||
support.unlink(source_name)
|
|
||||||
|
|
||||||
def test_main():
|
def test_main():
|
||||||
support.run_unittest(LineCacheTests)
|
support.run_unittest(LineCacheTests)
|
||||||
|
|
||||||
|
|
|
@ -393,6 +393,9 @@ C-API
|
||||||
Library
|
Library
|
||||||
-------
|
-------
|
||||||
|
|
||||||
|
- Issue #8782: Add a trailing newline in linecache.updatecache to the last line
|
||||||
|
of files without one.
|
||||||
|
|
||||||
- Issue #8729: Return NotImplemented from collections.Mapping.__eq__ when
|
- Issue #8729: Return NotImplemented from collections.Mapping.__eq__ when
|
||||||
comparing to a non-mapping.
|
comparing to a non-mapping.
|
||||||
|
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue