Skip to content

Commit 8e12485

Browse files
committed
sysexits.h
1 parent e2cca54 commit 8e12485

1 file changed

Lines changed: 108 additions & 0 deletions

File tree

system/include/sysexits.h

Lines changed: 108 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,108 @@
1+
/*
2+
* Copyright (c) 1987, 1993
3+
* The Regents of the University of California. All rights reserved.
4+
*
5+
* Redistribution and use in source and binary forms, with or without
6+
* modification, are permitted provided that the following conditions
7+
* are met:
8+
* 1. Redistributions of source code must retain the above copyright
9+
* notice, this list of conditions and the following disclaimer.
10+
* 2. Redistributions in binary form must reproduce the above copyright
11+
* notice, this list of conditions and the following disclaimer in the
12+
* documentation and/or other materials provided with the distribution.
13+
* 4. Neither the name of the University nor the names of its contributors
14+
* may be used to endorse or promote products derived from this software
15+
* without specific prior written permission.
16+
*
17+
* THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
18+
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
19+
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
20+
* ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
21+
* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
22+
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
23+
* OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
24+
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
25+
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
26+
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
27+
* SUCH DAMAGE.
28+
*
29+
* @(#)sysexits.h 8.1 (Berkeley) 6/2/93
30+
*/
31+
#ifndef _SYSEXITS_H
32+
#define _SYSEXITS_H 1
33+
/*
34+
* SYSEXITS.H -- Exit status codes for system programs.
35+
*
36+
* This include file attempts to categorize possible error
37+
* exit statuses for system programs, notably delivermail
38+
* and the Berkeley network.
39+
*
40+
* Error numbers begin at EX__BASE to reduce the possibility of
41+
* clashing with other exit statuses that random programs may
42+
* already return. The meaning of the codes is approximately
43+
* as follows:
44+
*
45+
* EX_USAGE -- The command was used incorrectly, e.g., with
46+
* the wrong number of arguments, a bad flag, a bad
47+
* syntax in a parameter, or whatever.
48+
* EX_DATAERR -- The input data was incorrect in some way.
49+
* This should only be used for user's data & not
50+
* system files.
51+
* EX_NOINPUT -- An input file (not a system file) did not
52+
* exist or was not readable. This could also include
53+
* errors like "No message" to a mailer (if it cared
54+
* to catch it).
55+
* EX_NOUSER -- The user specified did not exist. This might
56+
* be used for mail addresses or remote logins.
57+
* EX_NOHOST -- The host specified did not exist. This is used
58+
* in mail addresses or network requests.
59+
* EX_UNAVAILABLE -- A service is unavailable. This can occur
60+
* if a support program or file does not exist. This
61+
* can also be used as a catchall message when something
62+
* you wanted to do doesn't work, but you don't know
63+
* why.
64+
* EX_SOFTWARE -- An internal software error has been detected.
65+
* This should be limited to non-operating system related
66+
* errors as possible.
67+
* EX_OSERR -- An operating system error has been detected.
68+
* This is intended to be used for such things as "cannot
69+
* fork", "cannot create pipe", or the like. It includes
70+
* things like getuid returning a user that does not
71+
* exist in the passwd file.
72+
* EX_OSFILE -- Some system file (e.g., /etc/passwd, /etc/utmp,
73+
* etc.) does not exist, cannot be opened, or has some
74+
* sort of error (e.g., syntax error).
75+
* EX_CANTCREAT -- A (user specified) output file cannot be
76+
* created.
77+
* EX_IOERR -- An error occurred while doing I/O on some file.
78+
* EX_TEMPFAIL -- temporary failure, indicating something that
79+
* is not really an error. In sendmail, this means
80+
* that a mailer (e.g.) could not create a connection,
81+
* and the request should be reattempted later.
82+
* EX_PROTOCOL -- the remote system returned something that
83+
* was "not possible" during a protocol exchange.
84+
* EX_NOPERM -- You did not have sufficient permission to
85+
* perform the operation. This is not intended for
86+
* file system problems, which should use NOINPUT or
87+
* CANTCREAT, but rather for higher level permissions.
88+
*/
89+
#define EX_OK 0 /* successful termination */
90+
#define EX__BASE 64 /* base value for error messages */
91+
#define EX_USAGE 64 /* command line usage error */
92+
#define EX_DATAERR 65 /* data format error */
93+
#define EX_NOINPUT 66 /* cannot open input */
94+
#define EX_NOUSER 67 /* addressee unknown */
95+
#define EX_NOHOST 68 /* host name unknown */
96+
#define EX_UNAVAILABLE 69 /* service unavailable */
97+
#define EX_SOFTWARE 70 /* internal software error */
98+
#define EX_OSERR 71 /* system error (e.g., can't fork) */
99+
#define EX_OSFILE 72 /* critical OS file missing */
100+
#define EX_CANTCREAT 73 /* can't create (user) output file */
101+
#define EX_IOERR 74 /* input/output error */
102+
#define EX_TEMPFAIL 75 /* temp failure; user is invited to retry */
103+
#define EX_PROTOCOL 76 /* remote error in protocol */
104+
#define EX_NOPERM 77 /* permission denied */
105+
#define EX_CONFIG 78 /* configuration error */
106+
#define EX__MAX 78 /* maximum listed value */
107+
#endif /* sysexits.h */
108+

0 commit comments

Comments
 (0)