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