4 static char *rcsid
= "Id: log.c,v 1.1.1.1 2003/06/04 00:25:53 marka Exp";
8 * Copyright (c) 2000 Japan Network Information Center. All rights reserved.
10 * By using this file, you agree to the terms and conditions set forth bellow.
12 * LICENSE TERMS AND CONDITIONS
14 * The following License Terms and Conditions apply, unless a different
15 * license is obtained from Japan Network Information Center ("JPNIC"),
16 * a Japanese association, Kokusai-Kougyou-Kanda Bldg 6F, 2-3-4 Uchi-Kanda,
17 * Chiyoda-ku, Tokyo 101-0047, Japan.
19 * 1. Use, Modification and Redistribution (including distribution of any
20 * modified or derived work) in source and/or binary forms is permitted
21 * under this License Terms and Conditions.
23 * 2. Redistribution of source code must retain the copyright notices as they
24 * appear in each source code file, this License Terms and Conditions.
26 * 3. Redistribution in binary form must reproduce the Copyright Notice,
27 * this License Terms and Conditions, in the documentation and/or other
28 * materials provided with the distribution. For the purposes of binary
29 * distribution the "Copyright Notice" refers to the following language:
30 * "Copyright (c) 2000-2002 Japan Network Information Center. All rights reserved."
32 * 4. The name of JPNIC may not be used to endorse or promote products
33 * derived from this Software without specific prior written approval of
36 * 5. Disclaimer/Limitation of Liability: THIS SOFTWARE IS PROVIDED BY JPNIC
37 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
38 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A
39 * PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL JPNIC BE LIABLE
40 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
41 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
42 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR
43 * BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
44 * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
45 * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
46 * ADVISED OF THE POSSIBILITY OF SUCH DAMAGES.
60 #define LOGLEVEL_ENV "IDN_LOG_LEVEL"
63 #define DEFAULT_LOG_LEVEL idn_log_level_info
65 #define DEFAULT_LOG_LEVEL idn_log_level_error
68 static int log_level
= -1;
69 static idn_log_proc_t log_proc
;
71 static void initialize(void);
72 static void log(int level
, const char *fmt
, va_list args
);
73 static void log_to_stderr(int level
, const char *buf
);
76 idn_log_fatal(const char *fmt
, ...) {
80 log(idn_log_level_fatal
, fmt
, args
);
86 idn_log_error(const char *fmt
, ...) {
90 log(idn_log_level_error
, fmt
, args
);
95 idn_log_warning(const char *fmt
, ...) {
99 log(idn_log_level_warning
, fmt
, args
);
104 idn_log_info(const char *fmt
, ...) {
108 log(idn_log_level_info
, fmt
, args
);
113 idn_log_trace(const char *fmt
, ...) {
117 log(idn_log_level_trace
, fmt
, args
);
122 idn_log_dump(const char *fmt
, ...) {
126 log(idn_log_level_dump
, fmt
, args
);
131 idn_log_setlevel(int level
) {
137 idn_log_getlevel(void) {
144 idn_log_setproc(idn_log_proc_t proc
) {
146 log_proc
= log_to_stderr
;
156 if ((s
= getenv(LOGLEVEL_ENV
)) != NULL
) {
162 log_level
= DEFAULT_LOG_LEVEL
;
165 if (log_proc
== NULL
)
166 log_proc
= log_to_stderr
;
170 log(int level
, const char *fmt
, va_list args
) {
175 if (log_level
< level
)
179 (void)vsnprintf(buf
, sizeof(buf
), fmt
, args
);
181 /* Let's hope 1024 is enough.. */
182 (void)vsprintf(buf
, fmt
, args
);
184 (*log_proc
)(level
, buf
);
188 log_to_stderr(int level
, const char *buf
) {
193 case idn_log_level_fatal
:
196 case idn_log_level_error
:
199 case idn_log_level_warning
:
202 case idn_log_level_info
:
205 case idn_log_level_trace
:
208 case idn_log_level_dump
:
212 (void)sprintf(tmp
, "LEVEL%d", level
);
216 fprintf(stderr
, "%u: [%s] %s", (unsigned int)getpid(), title
, buf
);