source: trunk/src/emx/include/sysexits.h@ 2375

Last change on this file since 2375 was 1549, checked in by bird, 21 years ago

From FreeBSD 5.2

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