mirror of
				https://github.com/python/cpython.git
				synced 2025-10-31 13:41:24 +00:00 
			
		
		
		
	 89fad14944
			
		
	
	
		89fad14944
		
	
	
	
	
		
			
			svn+ssh://pythondev@svn.python.org/python/trunk ........ r78018 | georg.brandl | 2010-02-06 11:08:21 +0100 (Sa, 06 Feb 2010) | 1 line #7864: make deprecation notices a bit clearer. ........ r78035 | georg.brandl | 2010-02-06 23:44:17 +0100 (Sa, 06 Feb 2010) | 1 line Fix duplicate import. ........ r78036 | georg.brandl | 2010-02-06 23:49:47 +0100 (Sa, 06 Feb 2010) | 1 line Remove unused import. ........ r78037 | georg.brandl | 2010-02-06 23:59:15 +0100 (Sa, 06 Feb 2010) | 1 line No need to assign the results of expressions used only for side effects. ........ r78038 | georg.brandl | 2010-02-07 00:02:29 +0100 (So, 07 Feb 2010) | 1 line Add a missing import. ........ r78039 | georg.brandl | 2010-02-07 00:06:24 +0100 (So, 07 Feb 2010) | 1 line Add missing imports. ........ r78040 | georg.brandl | 2010-02-07 00:08:00 +0100 (So, 07 Feb 2010) | 1 line Fix a few UnboundLocalErrors in test_long. ........ r78042 | georg.brandl | 2010-02-07 00:12:12 +0100 (So, 07 Feb 2010) | 1 line Add missing import. ........ r78043 | georg.brandl | 2010-02-07 00:12:19 +0100 (So, 07 Feb 2010) | 1 line Remove duplicate test method. ........ r78046 | georg.brandl | 2010-02-07 00:18:00 +0100 (So, 07 Feb 2010) | 1 line Fix various missing import/unbound name errors. ........ r78048 | georg.brandl | 2010-02-07 00:23:45 +0100 (So, 07 Feb 2010) | 1 line We heard you like test failures so we put unbound locals in your test so that you can fail while you fail. ........ r78049 | georg.brandl | 2010-02-07 00:33:33 +0100 (So, 07 Feb 2010) | 1 line Fix import/access for some identifiers. _TestSharedCTypes does not seem to be executed? ........ r78050 | georg.brandl | 2010-02-07 00:34:10 +0100 (So, 07 Feb 2010) | 1 line Fix more unbound locals in code paths that do not seem to be used. ........ r78051 | georg.brandl | 2010-02-07 00:53:52 +0100 (So, 07 Feb 2010) | 1 line Add missing import when running these tests standalone. ........ r78052 | georg.brandl | 2010-02-07 00:54:04 +0100 (So, 07 Feb 2010) | 1 line Add missing import when running these tests standalone. ........ r78054 | georg.brandl | 2010-02-07 00:58:25 +0100 (So, 07 Feb 2010) | 1 line Add missing import. ........ r78059 | georg.brandl | 2010-02-07 12:34:15 +0100 (So, 07 Feb 2010) | 1 line Use "regexp" consistently. ........ r78075 | georg.brandl | 2010-02-07 13:16:12 +0100 (So, 07 Feb 2010) | 1 line Fix another duplicated test method. ........ r78076 | georg.brandl | 2010-02-07 13:19:43 +0100 (So, 07 Feb 2010) | 1 line Fix wrong usage of "except X, Y:". ........ r78077 | georg.brandl | 2010-02-07 13:25:50 +0100 (So, 07 Feb 2010) | 1 line Fix two redefined test methods. ........ r78078 | georg.brandl | 2010-02-07 13:27:06 +0100 (So, 07 Feb 2010) | 1 line Fix a redefined test method. ........ r78079 | georg.brandl | 2010-02-07 13:34:26 +0100 (So, 07 Feb 2010) | 1 line Add a minimal test for fnmatchcase(). ........ r78080 | georg.brandl | 2010-02-07 13:55:12 +0100 (So, 07 Feb 2010) | 1 line Remove duplicate test method. ........
		
			
				
	
	
		
			106 lines
		
	
	
	
		
			3 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			106 lines
		
	
	
	
		
			3 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
| """
 | |
| Path operations common to more than one OS
 | |
| Do not use directly.  The OS specific modules import the appropriate
 | |
| functions from this module themselves.
 | |
| """
 | |
| import os
 | |
| import stat
 | |
| 
 | |
| __all__ = ['commonprefix', 'exists', 'getatime', 'getctime', 'getmtime',
 | |
|            'getsize', 'isdir', 'isfile']
 | |
| 
 | |
| 
 | |
| # Does a path exist?
 | |
| # This is false for dangling symbolic links on systems that support them.
 | |
| def exists(path):
 | |
|     """Test whether a path exists.  Returns False for broken symbolic links"""
 | |
|     try:
 | |
|         os.stat(path)
 | |
|     except os.error:
 | |
|         return False
 | |
|     return True
 | |
| 
 | |
| 
 | |
| # This follows symbolic links, so both islink() and isdir() can be true
 | |
| # for the same path ono systems that support symlinks
 | |
| def isfile(path):
 | |
|     """Test whether a path is a regular file"""
 | |
|     try:
 | |
|         st = os.stat(path)
 | |
|     except os.error:
 | |
|         return False
 | |
|     return stat.S_ISREG(st.st_mode)
 | |
| 
 | |
| 
 | |
| # Is a path a directory?
 | |
| # This follows symbolic links, so both islink() and isdir()
 | |
| # can be true for the same path on systems that support symlinks
 | |
| def isdir(s):
 | |
|     """Return true if the pathname refers to an existing directory."""
 | |
|     try:
 | |
|         st = os.stat(s)
 | |
|     except os.error:
 | |
|         return False
 | |
|     return stat.S_ISDIR(st.st_mode)
 | |
| 
 | |
| 
 | |
| def getsize(filename):
 | |
|     """Return the size of a file, reported by os.stat()."""
 | |
|     return os.stat(filename).st_size
 | |
| 
 | |
| 
 | |
| def getmtime(filename):
 | |
|     """Return the last modification time of a file, reported by os.stat()."""
 | |
|     return os.stat(filename).st_mtime
 | |
| 
 | |
| 
 | |
| def getatime(filename):
 | |
|     """Return the last access time of a file, reported by os.stat()."""
 | |
|     return os.stat(filename).st_atime
 | |
| 
 | |
| 
 | |
| def getctime(filename):
 | |
|     """Return the metadata change time of a file, reported by os.stat()."""
 | |
|     return os.stat(filename).st_ctime
 | |
| 
 | |
| 
 | |
| # Return the longest prefix of all list elements.
 | |
| def commonprefix(m):
 | |
|     "Given a list of pathnames, returns the longest common leading component"
 | |
|     if not m: return ''
 | |
|     s1 = min(m)
 | |
|     s2 = max(m)
 | |
|     for i, c in enumerate(s1):
 | |
|         if c != s2[i]:
 | |
|             return s1[:i]
 | |
|     return s1
 | |
| 
 | |
| # Split a path in root and extension.
 | |
| # The extension is everything starting at the last dot in the last
 | |
| # pathname component; the root is everything before that.
 | |
| # It is always true that root + ext == p.
 | |
| 
 | |
| # Generic implementation of splitext, to be parametrized with
 | |
| # the separators
 | |
| def _splitext(p, sep, altsep, extsep):
 | |
|     """Split the extension from a pathname.
 | |
| 
 | |
|     Extension is everything from the last dot to the end, ignoring
 | |
|     leading dots.  Returns "(root, ext)"; ext may be empty."""
 | |
|     # NOTE: This code must work for text and bytes strings.
 | |
| 
 | |
|     sepIndex = p.rfind(sep)
 | |
|     if altsep:
 | |
|         altsepIndex = p.rfind(altsep)
 | |
|         sepIndex = max(sepIndex, altsepIndex)
 | |
| 
 | |
|     dotIndex = p.rfind(extsep)
 | |
|     if dotIndex > sepIndex:
 | |
|         # skip all leading dots
 | |
|         filenameIndex = sepIndex + 1
 | |
|         while filenameIndex < dotIndex:
 | |
|             if p[filenameIndex:filenameIndex+1] != extsep:
 | |
|                 return p[:dotIndex], p[dotIndex:]
 | |
|             filenameIndex += 1
 | |
| 
 | |
|     return p, p[:0]
 |