1990-10-21 17:17:08 +01:00
|
|
|
# Module 'stat'
|
1992-03-31 21:03:19 +02:00
|
|
|
#
|
1990-10-21 17:17:08 +01:00
|
|
|
# Defines constants and functions for interpreting stat/lstat struct
|
1992-03-31 21:03:19 +02:00
|
|
|
# as returned by os.stat() and os.lstat() (if it exists).
|
|
|
|
#
|
1990-10-21 17:17:08 +01:00
|
|
|
# Suggested usage: from stat import *
|
1992-03-31 21:03:19 +02:00
|
|
|
#
|
|
|
|
# XXX Strictly spoken, this module may have to be adapted for each POSIX
|
|
|
|
# implementation; in practice, however, the numeric constants used by
|
|
|
|
# stat() are almost universal (even for stat() emulations on non-UNIX
|
|
|
|
# systems like Macintosh or MS-DOS).
|
1990-10-21 17:17:08 +01:00
|
|
|
|
1992-03-31 21:03:19 +02:00
|
|
|
# Indices for stat struct members in tuple returned by os.stat()
|
1990-10-21 17:17:08 +01:00
|
|
|
|
|
|
|
ST_MODE = 0
|
|
|
|
ST_INO = 1
|
|
|
|
ST_DEV = 2
|
|
|
|
ST_NLINK = 3
|
|
|
|
ST_UID = 4
|
|
|
|
ST_GID = 5
|
|
|
|
ST_SIZE = 6
|
|
|
|
ST_ATIME = 7
|
|
|
|
ST_MTIME = 8
|
|
|
|
ST_CTIME = 9
|
|
|
|
|
1992-03-31 21:03:19 +02:00
|
|
|
# Extract bits from the mode
|
|
|
|
|
1990-10-31 12:25:23 +01:00
|
|
|
def S_IMODE(mode):
|
1992-03-31 21:03:19 +02:00
|
|
|
return mode & 07777
|
|
|
|
|
1990-10-21 17:17:08 +01:00
|
|
|
def S_IFMT(mode):
|
1992-03-31 21:03:19 +02:00
|
|
|
return mode & ~07777
|
|
|
|
|
|
|
|
# Constants used as S_IFMT() for various file types
|
|
|
|
# (not all are implemented on all systems)
|
1990-10-21 17:17:08 +01:00
|
|
|
|
|
|
|
S_IFDIR = 0040000
|
|
|
|
S_IFCHR = 0020000
|
|
|
|
S_IFBLK = 0060000
|
|
|
|
S_IFREG = 0100000
|
|
|
|
S_IFIFO = 0010000
|
|
|
|
S_IFLNK = 0120000
|
|
|
|
S_IFSOCK = 0140000
|
|
|
|
|
1992-03-31 21:03:19 +02:00
|
|
|
# Functions to test for each file type
|
|
|
|
|
1990-10-21 17:17:08 +01:00
|
|
|
def S_ISDIR(mode):
|
1992-01-01 20:35:13 +01:00
|
|
|
return S_IFMT(mode) == S_IFDIR
|
1990-10-21 17:17:08 +01:00
|
|
|
|
|
|
|
def S_ISCHR(mode):
|
1992-01-01 20:35:13 +01:00
|
|
|
return S_IFMT(mode) == S_IFCHR
|
1990-10-21 17:17:08 +01:00
|
|
|
|
|
|
|
def S_ISBLK(mode):
|
1992-01-01 20:35:13 +01:00
|
|
|
return S_IFMT(mode) == S_IFBLK
|
1990-10-21 17:17:08 +01:00
|
|
|
|
|
|
|
def S_ISREG(mode):
|
1992-01-01 20:35:13 +01:00
|
|
|
return S_IFMT(mode) == S_IFREG
|
1990-10-21 17:17:08 +01:00
|
|
|
|
|
|
|
def S_ISFIFO(mode):
|
1992-01-01 20:35:13 +01:00
|
|
|
return S_IFMT(mode) == S_IFIFO
|
1990-10-21 17:17:08 +01:00
|
|
|
|
|
|
|
def S_ISLNK(mode):
|
1992-01-01 20:35:13 +01:00
|
|
|
return S_IFMT(mode) == S_IFLNK
|
1990-10-21 17:17:08 +01:00
|
|
|
|
|
|
|
def S_ISSOCK(mode):
|
1992-01-01 20:35:13 +01:00
|
|
|
return S_IFMT(mode) == S_IFSOCK
|