xref: /minix/include/fmtmsg.h (revision 2fe8fb19)
1*2fe8fb19SBen Gras /*	$NetBSD: fmtmsg.h,v 1.3 2008/04/28 20:22:54 martin Exp $	*/
2*2fe8fb19SBen Gras 
3*2fe8fb19SBen Gras /*-
4*2fe8fb19SBen Gras  * Copyright (c) 1999 The NetBSD Foundation, Inc.
5*2fe8fb19SBen Gras  * All rights reserved.
6*2fe8fb19SBen Gras  *
7*2fe8fb19SBen Gras  * This code is derived from software contributed to The NetBSD Foundation
8*2fe8fb19SBen Gras  * by Klaus Klein.
9*2fe8fb19SBen Gras  *
10*2fe8fb19SBen Gras  * Redistribution and use in source and binary forms, with or without
11*2fe8fb19SBen Gras  * modification, are permitted provided that the following conditions
12*2fe8fb19SBen Gras  * are met:
13*2fe8fb19SBen Gras  * 1. Redistributions of source code must retain the above copyright
14*2fe8fb19SBen Gras  *    notice, this list of conditions and the following disclaimer.
15*2fe8fb19SBen Gras  * 2. Redistributions in binary form must reproduce the above copyright
16*2fe8fb19SBen Gras  *    notice, this list of conditions and the following disclaimer in the
17*2fe8fb19SBen Gras  *    documentation and/or other materials provided with the distribution.
18*2fe8fb19SBen Gras  *
19*2fe8fb19SBen Gras  * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
20*2fe8fb19SBen Gras  * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
21*2fe8fb19SBen Gras  * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
22*2fe8fb19SBen Gras  * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
23*2fe8fb19SBen Gras  * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
24*2fe8fb19SBen Gras  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
25*2fe8fb19SBen Gras  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
26*2fe8fb19SBen Gras  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
27*2fe8fb19SBen Gras  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
28*2fe8fb19SBen Gras  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
29*2fe8fb19SBen Gras  * POSSIBILITY OF SUCH DAMAGE.
30*2fe8fb19SBen Gras  */
31*2fe8fb19SBen Gras 
32*2fe8fb19SBen Gras #ifndef _FMTMSG_H_
33*2fe8fb19SBen Gras #define _FMTMSG_H_
34*2fe8fb19SBen Gras 
35*2fe8fb19SBen Gras /* Major Classifications: identifies the source of the condition. */
36*2fe8fb19SBen Gras #define MM_HARD		0x01L	/* Hardware */
37*2fe8fb19SBen Gras #define MM_SOFT		0x02L	/* Software */
38*2fe8fb19SBen Gras #define MM_FIRM		0x03L	/* Firmware */
39*2fe8fb19SBen Gras 
40*2fe8fb19SBen Gras /* Message Source Subclassifications: type of software. */
41*2fe8fb19SBen Gras #define MM_APPL		0x04L	/* Application */
42*2fe8fb19SBen Gras #define MM_UTIL		0x08L	/* Utility */
43*2fe8fb19SBen Gras #define MM_OPSYS	0x0cL	/* Operating system */
44*2fe8fb19SBen Gras 
45*2fe8fb19SBen Gras /* Display Subclassifications: where to display the message. */
46*2fe8fb19SBen Gras #define MM_PRINT	0x10L	/* Display on standard error */
47*2fe8fb19SBen Gras #define MM_CONSOLE	0x20L	/* Display on system console */
48*2fe8fb19SBen Gras 
49*2fe8fb19SBen Gras /* Status subclassifications: whether the application will recover. */
50*2fe8fb19SBen Gras #define MM_RECOVER	0x40L	/* Recoverable */
51*2fe8fb19SBen Gras #define MM_NRECOV	0x80L	/* Non-recoverable */
52*2fe8fb19SBen Gras 
53*2fe8fb19SBen Gras /* Severity: seriousness of the condition. */
54*2fe8fb19SBen Gras #define MM_NOSEV	0	/* No severity level provided */
55*2fe8fb19SBen Gras #define MM_HALT		1	/* Error causing application to halt */
56*2fe8fb19SBen Gras #define MM_ERROR	2	/* Encountered a non-fatal fault */
57*2fe8fb19SBen Gras #define MM_WARNING	3	/* Unusual non-error condition */
58*2fe8fb19SBen Gras #define MM_INFO		4	/* Informative message */
59*2fe8fb19SBen Gras 
60*2fe8fb19SBen Gras /* `Null' values for message components. */
61*2fe8fb19SBen Gras #define MM_NULLMC	0L		/* `Null' classsification component */
62*2fe8fb19SBen Gras #define MM_NULLLBL	(char *)0	/* `Null' label component */
63*2fe8fb19SBen Gras #define MM_NULLSEV	0		/* `Null' severity component */
64*2fe8fb19SBen Gras #define MM_NULLTXT	(char *)0	/* `Null' text component */
65*2fe8fb19SBen Gras #define MM_NULLACT	(char *)0	/* `Null' action component */
66*2fe8fb19SBen Gras #define MM_NULLTAG	(char *)0	/* `Null' tag component */
67*2fe8fb19SBen Gras 
68*2fe8fb19SBen Gras /* Return values for fmtmsg(). */
69*2fe8fb19SBen Gras #define MM_OK		0	/* Function succeeded */
70*2fe8fb19SBen Gras #define MM_NOTOK	(-1)	/* Function failed completely */
71*2fe8fb19SBen Gras #define MM_NOMSG	0x01	/* Unable to perform MM_PRINT */
72*2fe8fb19SBen Gras #define MM_NOCON	0x02	/* Unable to perform MM_CONSOLE */
73*2fe8fb19SBen Gras 
74*2fe8fb19SBen Gras #include <sys/cdefs.h>
75*2fe8fb19SBen Gras 
76*2fe8fb19SBen Gras __BEGIN_DECLS
77*2fe8fb19SBen Gras int	fmtmsg(long, const char *, int, const char *, const char *,
78*2fe8fb19SBen Gras 	    const char *);
79*2fe8fb19SBen Gras __END_DECLS
80*2fe8fb19SBen Gras 
81*2fe8fb19SBen Gras #endif /* !_FMTMSG_H_ */
82