mirror of
				https://github.com/python/cpython.git
				synced 2025-11-03 23:21:29 +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:
 | 
			
		||||
        del cache[filename]
 | 
			
		||||
    if not filename or filename[0] + filename[-1] == '<>':
 | 
			
		||||
    if not filename or (filename.startswith('<') and filename.endswith('>')):
 | 
			
		||||
        return []
 | 
			
		||||
 | 
			
		||||
    fullname = filename
 | 
			
		||||
    try:
 | 
			
		||||
        stat = os.stat(fullname)
 | 
			
		||||
    except os.error as msg:
 | 
			
		||||
    except OSError:
 | 
			
		||||
        basename = filename
 | 
			
		||||
 | 
			
		||||
        # Try for a __loader__, if available
 | 
			
		||||
| 
						 | 
				
			
			@ -114,20 +114,23 @@ def updatecache(filename, module_globals=None):
 | 
			
		|||
                fullname = os.path.join(dirname, basename)
 | 
			
		||||
            except (TypeError, AttributeError):
 | 
			
		||||
                # Not sufficiently string-like to do anything useful with.
 | 
			
		||||
                pass
 | 
			
		||||
            else:
 | 
			
		||||
                continue
 | 
			
		||||
            try:
 | 
			
		||||
                stat = os.stat(fullname)
 | 
			
		||||
                break
 | 
			
		||||
            except os.error:
 | 
			
		||||
                pass
 | 
			
		||||
        else:
 | 
			
		||||
            # No luck
 | 
			
		||||
            return []
 | 
			
		||||
    try:
 | 
			
		||||
        with open(fullname, 'rb') as fp:
 | 
			
		||||
            coding, line = tokenize.detect_encoding(fp.readline)
 | 
			
		||||
        with open(fullname, 'r', encoding=coding) as fp:
 | 
			
		||||
            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
 | 
			
		||||
    cache[filename] = size, mtime, lines, fullname
 | 
			
		||||
    return lines
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -31,6 +31,11 @@ def f():
 | 
			
		|||
 | 
			
		||||
'''
 | 
			
		||||
 | 
			
		||||
SOURCE_3 = '''
 | 
			
		||||
def f():
 | 
			
		||||
    return 3''' # No ending newline
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
class LineCacheTests(unittest.TestCase):
 | 
			
		||||
 | 
			
		||||
    def test_getline(self):
 | 
			
		||||
| 
						 | 
				
			
			@ -63,6 +68,13 @@ def test_getline(self):
 | 
			
		|||
        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:
 | 
			
		||||
| 
						 | 
				
			
			@ -81,9 +93,9 @@ def test_clearcache(self):
 | 
			
		|||
 | 
			
		||||
    def test_checkcache(self):
 | 
			
		||||
        getline = linecache.getline
 | 
			
		||||
        try:
 | 
			
		||||
        # Create a source file and cache its contents
 | 
			
		||||
        source_name = support.TESTFN + '.py'
 | 
			
		||||
        self.addCleanup(support.unlink, source_name)
 | 
			
		||||
        with open(source_name, 'w') as source:
 | 
			
		||||
            source.write(SOURCE_1)
 | 
			
		||||
        getline(source_name, 1)
 | 
			
		||||
| 
						 | 
				
			
			@ -112,9 +124,6 @@ def test_checkcache(self):
 | 
			
		|||
                self.assertEquals(line, getline(source_name, index + 1))
 | 
			
		||||
                source_list.append(line)
 | 
			
		||||
 | 
			
		||||
        finally:
 | 
			
		||||
            support.unlink(source_name)
 | 
			
		||||
 | 
			
		||||
def test_main():
 | 
			
		||||
    support.run_unittest(LineCacheTests)
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -393,6 +393,9 @@ C-API
 | 
			
		|||
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
 | 
			
		||||
  comparing to a non-mapping.
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue