""" | |
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: | |
st = 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) | |
n = min(len(s1), len(s2)) | |
for i in xrange(n): | |
if s1[i] != s2[i]: | |
return s1[:i] | |
return s1[:n] |