stat.py 1.7 KB
Newer Older
1 2 3 4 5
"""Constants/functions for interpreting results of os.stat() and os.lstat().

Suggested usage: from stat import *
"""

6
# Indices for stat struct members in the tuple returned by os.stat()
Guido van Rossum's avatar
Guido van Rossum committed
7 8 9 10 11 12 13 14 15 16 17 18

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

19 20
# Extract bits from the mode

21
def S_IMODE(mode):
22
    return mode & 0o7777
23

Guido van Rossum's avatar
Guido van Rossum committed
24
def S_IFMT(mode):
25
    return mode & 0o170000
26 27 28

# Constants used as S_IFMT() for various file types
# (not all are implemented on all systems)
Guido van Rossum's avatar
Guido van Rossum committed
29

30 31 32 33 34 35 36
S_IFDIR  = 0o040000
S_IFCHR  = 0o020000
S_IFBLK  = 0o060000
S_IFREG  = 0o100000
S_IFIFO  = 0o010000
S_IFLNK  = 0o120000
S_IFSOCK = 0o140000
Guido van Rossum's avatar
Guido van Rossum committed
37

38 39
# Functions to test for each file type

Guido van Rossum's avatar
Guido van Rossum committed
40
def S_ISDIR(mode):
Tim Peters's avatar
Tim Peters committed
41
    return S_IFMT(mode) == S_IFDIR
Guido van Rossum's avatar
Guido van Rossum committed
42 43

def S_ISCHR(mode):
Tim Peters's avatar
Tim Peters committed
44
    return S_IFMT(mode) == S_IFCHR
Guido van Rossum's avatar
Guido van Rossum committed
45 46

def S_ISBLK(mode):
Tim Peters's avatar
Tim Peters committed
47
    return S_IFMT(mode) == S_IFBLK
Guido van Rossum's avatar
Guido van Rossum committed
48 49

def S_ISREG(mode):
Tim Peters's avatar
Tim Peters committed
50
    return S_IFMT(mode) == S_IFREG
Guido van Rossum's avatar
Guido van Rossum committed
51 52

def S_ISFIFO(mode):
Tim Peters's avatar
Tim Peters committed
53
    return S_IFMT(mode) == S_IFIFO
Guido van Rossum's avatar
Guido van Rossum committed
54 55

def S_ISLNK(mode):
Tim Peters's avatar
Tim Peters committed
56
    return S_IFMT(mode) == S_IFLNK
Guido van Rossum's avatar
Guido van Rossum committed
57 58

def S_ISSOCK(mode):
Tim Peters's avatar
Tim Peters committed
59
    return S_IFMT(mode) == S_IFSOCK
60 61 62

# Names for permission bits

63 64
S_ISUID = 0o4000
S_ISGID = 0o2000
65
S_ENFMT = S_ISGID
66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81
S_ISVTX = 0o1000
S_IREAD = 0o0400
S_IWRITE = 0o0200
S_IEXEC = 0o0100
S_IRWXU = 0o0700
S_IRUSR = 0o0400
S_IWUSR = 0o0200
S_IXUSR = 0o0100
S_IRWXG = 0o0070
S_IRGRP = 0o0040
S_IWGRP = 0o0020
S_IXGRP = 0o0010
S_IRWXO = 0o0007
S_IROTH = 0o0004
S_IWOTH = 0o0002
S_IXOTH = 0o0001
82 83 84 85 86 87 88 89 90 91 92 93 94

# Names for file flags

UF_NODUMP    = 0x00000001
UF_IMMUTABLE = 0x00000002
UF_APPEND    = 0x00000004
UF_OPAQUE    = 0x00000008
UF_NOUNLINK  = 0x00000010
SF_ARCHIVED  = 0x00010000
SF_IMMUTABLE = 0x00020000
SF_APPEND    = 0x00040000
SF_NOUNLINK  = 0x00100000
SF_SNAPSHOT  = 0x00200000