summaryrefslogtreecommitdiffstats
path: root/Lib
diff options
context:
space:
mode:
authorBenjamin Peterson <benjamin@python.org>2010-05-21 21:31:24 (GMT)
committerBenjamin Peterson <benjamin@python.org>2010-05-21 21:31:24 (GMT)
commit266e45486659472d3b7c63d397a8083968a0f33f (patch)
treec59eb9e4532f8ddfee9a6b8d69471be73ac298a9 /Lib
parentdd59f1bf92958c698cc4223e9762e5d46a498c38 (diff)
downloadcpython-266e45486659472d3b7c63d397a8083968a0f33f.zip
cpython-266e45486659472d3b7c63d397a8083968a0f33f.tar.gz
cpython-266e45486659472d3b7c63d397a8083968a0f33f.tar.bz2
ensure the last line has a trailing newline #8782
Diffstat (limited to 'Lib')
-rw-r--r--Lib/linecache.py2
-rw-r--r--Lib/test/test_linecache.py12
2 files changed, 14 insertions, 0 deletions
diff --git a/Lib/linecache.py b/Lib/linecache.py
index e7c33e1..c999851 100644
--- a/Lib/linecache.py
+++ b/Lib/linecache.py
@@ -133,6 +133,8 @@ def updatecache(filename, module_globals=None):
except IOError, msg:
## print '*** Cannot open', fullname, ':', msg
return []
+ if lines and not lines[-1].endswith('\n'):
+ lines[-1] += '\n'
size, mtime = stat.st_size, stat.st_mtime
cache[filename] = size, mtime, lines, fullname
return lines
diff --git a/Lib/test/test_linecache.py b/Lib/test/test_linecache.py
index 2dd3672d..88346be 100644
--- a/Lib/test/test_linecache.py
+++ b/Lib/test/test_linecache.py
@@ -31,6 +31,11 @@ a = f()
'''
+SOURCE_3 = '''
+def f():
+ return 3''' # No ending newline
+
+
class LineCacheTests(unittest.TestCase):
def test_getline(self):
@@ -63,6 +68,13 @@ class LineCacheTests(unittest.TestCase):
empty = linecache.getlines('a/b/c/__init__.py')
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):
cached = []
for entry in TESTS: