2 Path operations common to more than one OS
3 Do not use directly. The OS specific modules import the appropriate
4 functions from this module themselves.
9 __all__
= ['commonprefix', 'exists', 'getatime', 'getctime', 'getmtime',
10 'getsize', 'isdir', 'isfile']
14 # This is false for dangling symbolic links on systems that support them.
16 """Test whether a path exists. Returns False for broken symbolic links"""
24 # This follows symbolic links, so both islink() and isdir() can be true
25 # for the same path ono systems that support symlinks
27 """Test whether a path is a regular file"""
32 return stat
.S_ISREG(st
.st_mode
)
35 # Is a path a directory?
36 # This follows symbolic links, so both islink() and isdir()
37 # can be true for the same path on systems that support symlinks
39 """Return true if the pathname refers to an existing directory."""
44 return stat
.S_ISDIR(st
.st_mode
)
47 def getsize(filename
):
48 """Return the size of a file, reported by os.stat()."""
49 return os
.stat(filename
).st_size
52 def getmtime(filename
):
53 """Return the last modification time of a file, reported by os.stat()."""
54 return os
.stat(filename
).st_mtime
57 def getatime(filename
):
58 """Return the last access time of a file, reported by os.stat()."""
59 return os
.stat(filename
).st_atime
62 def getctime(filename
):
63 """Return the metadata change time of a file, reported by os.stat()."""
64 return os
.stat(filename
).st_ctime
67 # Return the longest prefix of all list elements.
69 "Given a list of pathnames, returns the longest common leading component"
73 for i
, c
in enumerate(s1
):
78 # Split a path in root and extension.
79 # The extension is everything starting at the last dot in the last
80 # pathname component; the root is everything before that.
81 # It is always true that root + ext == p.
83 # Generic implementation of splitext, to be parametrized with
85 def _splitext(p
, sep
, altsep
, extsep
):
86 """Split the extension from a pathname.
88 Extension is everything from the last dot to the end, ignoring
89 leading dots. Returns "(root, ext)"; ext may be empty."""
90 # NOTE: This code must work for text and bytes strings.
92 sepIndex
= p
.rfind(sep
)
94 altsepIndex
= p
.rfind(altsep
)
95 sepIndex
= max(sepIndex
, altsepIndex
)
97 dotIndex
= p
.rfind(extsep
)
98 if dotIndex
> sepIndex
:
99 # skip all leading dots
100 filenameIndex
= sepIndex
+ 1
101 while filenameIndex
< dotIndex
:
102 if p
[filenameIndex
:filenameIndex
+1] != extsep
:
103 return p
[:dotIndex
], p
[dotIndex
:]