xref: /minix3/external/bsd/bind/dist/contrib/idn/idnkit-1.0-src/wsock/common/printf.c (revision 00b67f09dd46474d133c95011a48590a8e8f94c7)
1*00b67f09SDavid van Moolenbroek /*	$NetBSD: printf.c,v 1.3 2014/12/10 04:37:56 christos Exp $	*/
2*00b67f09SDavid van Moolenbroek 
3*00b67f09SDavid van Moolenbroek /*
4*00b67f09SDavid van Moolenbroek  * printf.c - printf like debug print function
5*00b67f09SDavid van Moolenbroek  */
6*00b67f09SDavid van Moolenbroek 
7*00b67f09SDavid van Moolenbroek /*
8*00b67f09SDavid van Moolenbroek  * Copyright (c) 2000,2002 Japan Network Information Center.
9*00b67f09SDavid van Moolenbroek  * All rights reserved.
10*00b67f09SDavid van Moolenbroek  *
11*00b67f09SDavid van Moolenbroek  * By using this file, you agree to the terms and conditions set forth bellow.
12*00b67f09SDavid van Moolenbroek  *
13*00b67f09SDavid van Moolenbroek  * 			LICENSE TERMS AND CONDITIONS
14*00b67f09SDavid van Moolenbroek  *
15*00b67f09SDavid van Moolenbroek  * The following License Terms and Conditions apply, unless a different
16*00b67f09SDavid van Moolenbroek  * license is obtained from Japan Network Information Center ("JPNIC"),
17*00b67f09SDavid van Moolenbroek  * a Japanese association, Kokusai-Kougyou-Kanda Bldg 6F, 2-3-4 Uchi-Kanda,
18*00b67f09SDavid van Moolenbroek  * Chiyoda-ku, Tokyo 101-0047, Japan.
19*00b67f09SDavid van Moolenbroek  *
20*00b67f09SDavid van Moolenbroek  * 1. Use, Modification and Redistribution (including distribution of any
21*00b67f09SDavid van Moolenbroek  *    modified or derived work) in source and/or binary forms is permitted
22*00b67f09SDavid van Moolenbroek  *    under this License Terms and Conditions.
23*00b67f09SDavid van Moolenbroek  *
24*00b67f09SDavid van Moolenbroek  * 2. Redistribution of source code must retain the copyright notices as they
25*00b67f09SDavid van Moolenbroek  *    appear in each source code file, this License Terms and Conditions.
26*00b67f09SDavid van Moolenbroek  *
27*00b67f09SDavid van Moolenbroek  * 3. Redistribution in binary form must reproduce the Copyright Notice,
28*00b67f09SDavid van Moolenbroek  *    this License Terms and Conditions, in the documentation and/or other
29*00b67f09SDavid van Moolenbroek  *    materials provided with the distribution.  For the purposes of binary
30*00b67f09SDavid van Moolenbroek  *    distribution the "Copyright Notice" refers to the following language:
31*00b67f09SDavid van Moolenbroek  *    "Copyright (c) 2000-2002 Japan Network Information Center.  All rights reserved."
32*00b67f09SDavid van Moolenbroek  *
33*00b67f09SDavid van Moolenbroek  * 4. The name of JPNIC may not be used to endorse or promote products
34*00b67f09SDavid van Moolenbroek  *    derived from this Software without specific prior written approval of
35*00b67f09SDavid van Moolenbroek  *    JPNIC.
36*00b67f09SDavid van Moolenbroek  *
37*00b67f09SDavid van Moolenbroek  * 5. Disclaimer/Limitation of Liability: THIS SOFTWARE IS PROVIDED BY JPNIC
38*00b67f09SDavid van Moolenbroek  *    "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
39*00b67f09SDavid van Moolenbroek  *    LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A
40*00b67f09SDavid van Moolenbroek  *    PARTICULAR PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL JPNIC BE LIABLE
41*00b67f09SDavid van Moolenbroek  *    FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
42*00b67f09SDavid van Moolenbroek  *    CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
43*00b67f09SDavid van Moolenbroek  *    SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR
44*00b67f09SDavid van Moolenbroek  *    BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
45*00b67f09SDavid van Moolenbroek  *    WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
46*00b67f09SDavid van Moolenbroek  *    OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
47*00b67f09SDavid van Moolenbroek  *    ADVISED OF THE POSSIBILITY OF SUCH DAMAGES.
48*00b67f09SDavid van Moolenbroek  */
49*00b67f09SDavid van Moolenbroek 
50*00b67f09SDavid van Moolenbroek #include <windows.h>
51*00b67f09SDavid van Moolenbroek #include <stdio.h>
52*00b67f09SDavid van Moolenbroek #include <stdlib.h>
53*00b67f09SDavid van Moolenbroek #include <string.h>
54*00b67f09SDavid van Moolenbroek #include <process.h>
55*00b67f09SDavid van Moolenbroek 
56*00b67f09SDavid van Moolenbroek #include "wrapcommon.h"
57*00b67f09SDavid van Moolenbroek 
58*00b67f09SDavid van Moolenbroek /*
59*00b67f09SDavid van Moolenbroek  * Debug Tracer for DLL
60*00b67f09SDavid van Moolenbroek  */
61*00b67f09SDavid van Moolenbroek 
62*00b67f09SDavid van Moolenbroek static char	logfile_name[256];
63*00b67f09SDavid van Moolenbroek static int	log_level = -1;
64*00b67f09SDavid van Moolenbroek static char	log_header[30];
65*00b67f09SDavid van Moolenbroek 
66*00b67f09SDavid van Moolenbroek void
idnPrintf(char * fmt,...)67*00b67f09SDavid van Moolenbroek idnPrintf(char *fmt, ...) {
68*00b67f09SDavid van Moolenbroek 	va_list arg_ptr;
69*00b67f09SDavid van Moolenbroek 	FILE *fp;
70*00b67f09SDavid van Moolenbroek 	char msg[512];
71*00b67f09SDavid van Moolenbroek 
72*00b67f09SDavid van Moolenbroek 	if (log_level < 0 || logfile_name[0] == '\0')
73*00b67f09SDavid van Moolenbroek 		return;
74*00b67f09SDavid van Moolenbroek 
75*00b67f09SDavid van Moolenbroek 	va_start(arg_ptr, fmt);
76*00b67f09SDavid van Moolenbroek 	vsprintf(msg, fmt, arg_ptr);
77*00b67f09SDavid van Moolenbroek 	va_end(arg_ptr);
78*00b67f09SDavid van Moolenbroek 
79*00b67f09SDavid van Moolenbroek 	if ((fp = fopen(logfile_name, "a")) != NULL) {
80*00b67f09SDavid van Moolenbroek 		fputs(log_header, fp);
81*00b67f09SDavid van Moolenbroek 		fputs(msg, fp);
82*00b67f09SDavid van Moolenbroek 		fclose(fp);
83*00b67f09SDavid van Moolenbroek 	}
84*00b67f09SDavid van Moolenbroek }
85*00b67f09SDavid van Moolenbroek 
86*00b67f09SDavid van Moolenbroek void
idnLogPrintf(int level,char * fmt,...)87*00b67f09SDavid van Moolenbroek idnLogPrintf(int level, char *fmt, ...) {
88*00b67f09SDavid van Moolenbroek 	va_list arg_ptr;
89*00b67f09SDavid van Moolenbroek 	FILE *fp;
90*00b67f09SDavid van Moolenbroek 	char msg[512];
91*00b67f09SDavid van Moolenbroek 
92*00b67f09SDavid van Moolenbroek 	if (level > log_level || logfile_name[0] == '\0')
93*00b67f09SDavid van Moolenbroek 		return;
94*00b67f09SDavid van Moolenbroek 
95*00b67f09SDavid van Moolenbroek 	va_start(arg_ptr, fmt);
96*00b67f09SDavid van Moolenbroek 	vsprintf(msg, fmt, arg_ptr);
97*00b67f09SDavid van Moolenbroek 	va_end(arg_ptr);
98*00b67f09SDavid van Moolenbroek 
99*00b67f09SDavid van Moolenbroek 	if ((fp = fopen(logfile_name, "a")) != NULL) {
100*00b67f09SDavid van Moolenbroek 		fputs(log_header, fp);
101*00b67f09SDavid van Moolenbroek 		fputs(msg, fp);
102*00b67f09SDavid van Moolenbroek 		fclose(fp);
103*00b67f09SDavid van Moolenbroek 	}
104*00b67f09SDavid van Moolenbroek }
105*00b67f09SDavid van Moolenbroek 
106*00b67f09SDavid van Moolenbroek static void
log_proc(int level,const char * msg)107*00b67f09SDavid van Moolenbroek log_proc(int level, const char *msg) {
108*00b67f09SDavid van Moolenbroek 	FILE *fp;
109*00b67f09SDavid van Moolenbroek 
110*00b67f09SDavid van Moolenbroek 	if (log_level < 0 || logfile_name[0] == '\0')
111*00b67f09SDavid van Moolenbroek 		return;
112*00b67f09SDavid van Moolenbroek 
113*00b67f09SDavid van Moolenbroek 	if ((fp = fopen(logfile_name, "a")) != NULL) {
114*00b67f09SDavid van Moolenbroek 		fputs(msg, fp);
115*00b67f09SDavid van Moolenbroek 		fclose(fp);
116*00b67f09SDavid van Moolenbroek 	}
117*00b67f09SDavid van Moolenbroek }
118*00b67f09SDavid van Moolenbroek 
119*00b67f09SDavid van Moolenbroek void
idnLogInit(const char * title)120*00b67f09SDavid van Moolenbroek idnLogInit(const char *title) {
121*00b67f09SDavid van Moolenbroek 	log_level = idnGetLogLevel();
122*00b67f09SDavid van Moolenbroek 	/* If log file is not stored in the registry, don't do logging. */
123*00b67f09SDavid van Moolenbroek 	if (idnGetLogFile(logfile_name, sizeof(logfile_name)) == FALSE) {
124*00b67f09SDavid van Moolenbroek 		log_level = -1;
125*00b67f09SDavid van Moolenbroek 	}
126*00b67f09SDavid van Moolenbroek 	sprintf(log_header, "%08x %-.16s: ", getpid(), title);
127*00b67f09SDavid van Moolenbroek 	idn_log_setproc(log_proc);
128*00b67f09SDavid van Moolenbroek 	idn_log_setlevel(log_level < 0 ? 0 : log_level);
129*00b67f09SDavid van Moolenbroek }
130*00b67f09SDavid van Moolenbroek 
131*00b67f09SDavid van Moolenbroek void
idnLogReset(void)132*00b67f09SDavid van Moolenbroek idnLogReset(void) {
133*00b67f09SDavid van Moolenbroek 	idn_log_setproc(log_proc);
134*00b67f09SDavid van Moolenbroek }
135*00b67f09SDavid van Moolenbroek 
136*00b67f09SDavid van Moolenbroek void
idnLogFinish(void)137*00b67f09SDavid van Moolenbroek idnLogFinish(void) {
138*00b67f09SDavid van Moolenbroek 	idn_log_setproc(NULL);
139*00b67f09SDavid van Moolenbroek 	/* idn_log_setlevel(0); */
140*00b67f09SDavid van Moolenbroek }
141