aboutsummaryrefslogtreecommitdiffstats
path: root/contrib/python/Twisted/py3/twisted/application/runner/_exit.py
blob: 3d6bc10f6f985599cb20a4f5254872c6d8649fa1 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
# -*- test-case-name: twisted.application.runner.test.test_exit -*-
# Copyright (c) Twisted Matrix Laboratories.
# See LICENSE for details.

"""
System exit support.
"""

import typing
from enum import IntEnum
from sys import exit as sysexit, stderr, stdout
from typing import Union

try:
    import posix as Status
except ImportError:

    class Status:  # type: ignore[no-redef]
        """
        Object to hang C{EX_*} values off of as a substitute for L{posix}.
        """

        EX__BASE = 64

        EX_OK = 0
        EX_USAGE = EX__BASE
        EX_DATAERR = EX__BASE + 1
        EX_NOINPUT = EX__BASE + 2
        EX_NOUSER = EX__BASE + 3
        EX_NOHOST = EX__BASE + 4
        EX_UNAVAILABLE = EX__BASE + 5
        EX_SOFTWARE = EX__BASE + 6
        EX_OSERR = EX__BASE + 7
        EX_OSFILE = EX__BASE + 8
        EX_CANTCREAT = EX__BASE + 9
        EX_IOERR = EX__BASE + 10
        EX_TEMPFAIL = EX__BASE + 11
        EX_PROTOCOL = EX__BASE + 12
        EX_NOPERM = EX__BASE + 13
        EX_CONFIG = EX__BASE + 14


class ExitStatus(IntEnum):
    """
    Standard exit status codes for system programs.

    @cvar EX_OK: Successful termination.
    @cvar EX_USAGE: Command line usage error.
    @cvar EX_DATAERR: Data format error.
    @cvar EX_NOINPUT: Cannot open input.
    @cvar EX_NOUSER: Addressee unknown.
    @cvar EX_NOHOST: Host name unknown.
    @cvar EX_UNAVAILABLE: Service unavailable.
    @cvar EX_SOFTWARE: Internal software error.
    @cvar EX_OSERR: System error (e.g., can't fork).
    @cvar EX_OSFILE: Critical OS file missing.
    @cvar EX_CANTCREAT: Can't create (user) output file.
    @cvar EX_IOERR: Input/output error.
    @cvar EX_TEMPFAIL: Temporary failure; the user is invited to retry.
    @cvar EX_PROTOCOL: Remote error in protocol.
    @cvar EX_NOPERM: Permission denied.
    @cvar EX_CONFIG: Configuration error.
    """

    EX_OK = Status.EX_OK
    EX_USAGE = Status.EX_USAGE
    EX_DATAERR = Status.EX_DATAERR
    EX_NOINPUT = Status.EX_NOINPUT
    EX_NOUSER = Status.EX_NOUSER
    EX_NOHOST = Status.EX_NOHOST
    EX_UNAVAILABLE = Status.EX_UNAVAILABLE
    EX_SOFTWARE = Status.EX_SOFTWARE
    EX_OSERR = Status.EX_OSERR
    EX_OSFILE = Status.EX_OSFILE
    EX_CANTCREAT = Status.EX_CANTCREAT
    EX_IOERR = Status.EX_IOERR
    EX_TEMPFAIL = Status.EX_TEMPFAIL
    EX_PROTOCOL = Status.EX_PROTOCOL
    EX_NOPERM = Status.EX_NOPERM
    EX_CONFIG = Status.EX_CONFIG


def exit(status: Union[int, ExitStatus], message: str = "") -> "typing.NoReturn":
    """
    Exit the python interpreter with the given status and an optional message.

    @param status: An exit status. An appropriate value from L{ExitStatus} is
        recommended.
    @param message: An optional message to print.
    """
    if message:
        if status == ExitStatus.EX_OK:
            out = stdout
        else:
            out = stderr
        out.write(message)
        out.write("\n")

    sysexit(status)