Merge remote-tracking branch 'origin/master'
[unleashed/lotheac.git] / usr / src / lib / libtecla / common / errmsg.h
blobab0b1599ea717d349a9020e3fb133496490e6afd
1 #ifndef errmsg_h
2 #define errmsg_h
4 /*
5 * Copyright (c) 2000, 2001, 2002, 2003, 2004 by Martin C. Shepherd.
6 *
7 * All rights reserved.
8 *
9 * Permission is hereby granted, free of charge, to any person obtaining a
10 * copy of this software and associated documentation files (the
11 * "Software"), to deal in the Software without restriction, including
12 * without limitation the rights to use, copy, modify, merge, publish,
13 * distribute, and/or sell copies of the Software, and to permit persons
14 * to whom the Software is furnished to do so, provided that the above
15 * copyright notice(s) and this permission notice appear in all copies of
16 * the Software and that both the above copyright notice(s) and this
17 * permission notice appear in supporting documentation.
19 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
20 * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
21 * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT
22 * OF THIRD PARTY RIGHTS. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR
23 * HOLDERS INCLUDED IN THIS NOTICE BE LIABLE FOR ANY CLAIM, OR ANY SPECIAL
24 * INDIRECT OR CONSEQUENTIAL DAMAGES, OR ANY DAMAGES WHATSOEVER RESULTING
25 * FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT,
26 * NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION
27 * WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
29 * Except as contained in this notice, the name of a copyright holder
30 * shall not be used in advertising or otherwise to promote the sale, use
31 * or other dealings in this Software without prior written authorization
32 * of the copyright holder.
35 #pragma ident "%Z%%M% %I% %E% SMI"
38 * Set the longest expected length of an error message (excluding its
39 * '\0' terminator. Since any message over a nominal terminal width of
40 * 80 characters is going to look a mess, it makes no sense to support
41 * huge lengths. Note that many uses of strings declared with this
42 * macro assume that it will be at least 81, so don't reduce it below
43 * this limit.
45 #define ERR_MSG_LEN 128
48 * Provide an opaque typedef to the error-message object.
50 typedef struct ErrMsg ErrMsg;
53 * The following token is used to terminate the argument lists of calls
54 * to _err_record_msg().
56 #define END_ERR_MSG ((const char *)0)
59 * Allocate a new error-message buffer.
61 ErrMsg *_new_ErrMsg(void);
64 * Delete an error message buffer.
66 ErrMsg *_del_ErrMsg(ErrMsg *err);
69 * Concatenate a list of string arguments into the specified buffer, buff[],
70 * which has an allocated size of buffdim characters.
71 * The last argument must be END_ERR_MSG to terminate the argument list.
73 void _err_record_msg(ErrMsg *err, ...);
76 * Replace the current error message with an empty string.
78 void _err_clear_msg(ErrMsg *err);
81 * Return a pointer to the error message buffer. This is
82 * a '\0' terminated character array containing ERR_MSG_LEN+1
83 * elements.
85 char *_err_get_msg(ErrMsg *err);
87 #endif