Merged revisions 81432 via svnmerge from

svn+ssh://pythondev@svn.python.org/python/trunk

........
  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
........
This commit is contained in:
Benjamin Peterson 2010-05-21 21:45:16 +00:00
parent f28ae81741
commit a3401654e1
3 changed files with 19 additions and 0 deletions

View file

@ -133,6 +133,8 @@ def updatecache(filename, module_globals=None):
except IOError, msg: except IOError, msg:
## print '*** Cannot open', fullname, ':', msg ## print '*** Cannot open', fullname, ':', msg
return [] return []
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

View file

@ -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,15 @@ 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):
try:
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"])
finally:
support.unlink(support.TESTFN)
def test_clearcache(self): def test_clearcache(self):
cached = [] cached = []
for entry in TESTS: for entry in TESTS:

View file

@ -55,6 +55,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.