xref: /minix3/external/bsd/bind/dist/contrib/idn/idnkit-1.0-src/lib/debug.c (revision 00b67f09dd46474d133c95011a48590a8e8f94c7)
1*00b67f09SDavid van Moolenbroek /*	$NetBSD: debug.c,v 1.4 2014/12/10 04:37:55 christos Exp $	*/
2*00b67f09SDavid van Moolenbroek 
3*00b67f09SDavid van Moolenbroek #ifndef lint
4*00b67f09SDavid van Moolenbroek static char *rcsid = "Id: debug.c,v 1.1 2003/06/04 00:25:51 marka Exp ";
5*00b67f09SDavid van Moolenbroek #endif
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 <config.h>
51*00b67f09SDavid van Moolenbroek 
52*00b67f09SDavid van Moolenbroek #include <stdio.h>
53*00b67f09SDavid van Moolenbroek #include <stdarg.h>
54*00b67f09SDavid van Moolenbroek #include <stdlib.h>
55*00b67f09SDavid van Moolenbroek #include <string.h>
56*00b67f09SDavid van Moolenbroek 
57*00b67f09SDavid van Moolenbroek #include <idn/debug.h>
58*00b67f09SDavid van Moolenbroek 
59*00b67f09SDavid van Moolenbroek static char *hex = "0123456789abcdef";
60*00b67f09SDavid van Moolenbroek 
61*00b67f09SDavid van Moolenbroek #define STRING_MAXBYTES	200
62*00b67f09SDavid van Moolenbroek #define STRING_NBUFS	4
63*00b67f09SDavid van Moolenbroek static char bufs[STRING_NBUFS][STRING_MAXBYTES + 16];	/* +16 for margin */
64*00b67f09SDavid van Moolenbroek static int bufno = 0;
65*00b67f09SDavid van Moolenbroek 
66*00b67f09SDavid van Moolenbroek char *
idn__debug_hexstring(const char * s,int maxbytes)67*00b67f09SDavid van Moolenbroek idn__debug_hexstring(const char *s, int maxbytes) {
68*00b67f09SDavid van Moolenbroek 	char *buf = bufs[bufno];
69*00b67f09SDavid van Moolenbroek 	char *p;
70*00b67f09SDavid van Moolenbroek 	int i;
71*00b67f09SDavid van Moolenbroek 
72*00b67f09SDavid van Moolenbroek 	if (maxbytes > STRING_MAXBYTES)
73*00b67f09SDavid van Moolenbroek 		maxbytes = STRING_MAXBYTES;
74*00b67f09SDavid van Moolenbroek 
75*00b67f09SDavid van Moolenbroek 	for (i = 0, p = buf; i < maxbytes; i += 3, s++) {
76*00b67f09SDavid van Moolenbroek 		int c = *(unsigned char *)s;
77*00b67f09SDavid van Moolenbroek 
78*00b67f09SDavid van Moolenbroek 		if (c == '\0')
79*00b67f09SDavid van Moolenbroek 			break;
80*00b67f09SDavid van Moolenbroek 		*p++ = hex[c >> 4];
81*00b67f09SDavid van Moolenbroek 		*p++ = hex[c & 15];
82*00b67f09SDavid van Moolenbroek 		*p++ = ' ';
83*00b67f09SDavid van Moolenbroek 	}
84*00b67f09SDavid van Moolenbroek 
85*00b67f09SDavid van Moolenbroek 	if (i >= maxbytes)
86*00b67f09SDavid van Moolenbroek 		strcpy(p, "...");
87*00b67f09SDavid van Moolenbroek 	else
88*00b67f09SDavid van Moolenbroek 		*p = '\0';
89*00b67f09SDavid van Moolenbroek 
90*00b67f09SDavid van Moolenbroek 	bufno = (bufno + 1) % STRING_NBUFS;
91*00b67f09SDavid van Moolenbroek 	return (buf);
92*00b67f09SDavid van Moolenbroek }
93*00b67f09SDavid van Moolenbroek 
94*00b67f09SDavid van Moolenbroek char *
idn__debug_xstring(const char * s,int maxbytes)95*00b67f09SDavid van Moolenbroek idn__debug_xstring(const char *s, int maxbytes) {
96*00b67f09SDavid van Moolenbroek 	char *buf = bufs[bufno];
97*00b67f09SDavid van Moolenbroek 	char *p;
98*00b67f09SDavid van Moolenbroek 	int i;
99*00b67f09SDavid van Moolenbroek 
100*00b67f09SDavid van Moolenbroek 	if (maxbytes > STRING_MAXBYTES)
101*00b67f09SDavid van Moolenbroek 		maxbytes = STRING_MAXBYTES;
102*00b67f09SDavid van Moolenbroek 
103*00b67f09SDavid van Moolenbroek 	i = 0;
104*00b67f09SDavid van Moolenbroek 	p = buf;
105*00b67f09SDavid van Moolenbroek 	while (i < maxbytes) {
106*00b67f09SDavid van Moolenbroek 		int c = *(unsigned char *)s;
107*00b67f09SDavid van Moolenbroek 
108*00b67f09SDavid van Moolenbroek 		if (c == '\0') {
109*00b67f09SDavid van Moolenbroek 			break;
110*00b67f09SDavid van Moolenbroek 		} else if (0x20 <= c && c <= 0x7e) {
111*00b67f09SDavid van Moolenbroek 			*p++ = c;
112*00b67f09SDavid van Moolenbroek 			i++;
113*00b67f09SDavid van Moolenbroek 		} else {
114*00b67f09SDavid van Moolenbroek 			*p++ = '\\';
115*00b67f09SDavid van Moolenbroek 			*p++ = 'x';
116*00b67f09SDavid van Moolenbroek 			*p++ = hex[c >> 4];
117*00b67f09SDavid van Moolenbroek 			*p++ = hex[c & 15];
118*00b67f09SDavid van Moolenbroek 			i += 4;
119*00b67f09SDavid van Moolenbroek 		}
120*00b67f09SDavid van Moolenbroek 		s++;
121*00b67f09SDavid van Moolenbroek 	}
122*00b67f09SDavid van Moolenbroek 
123*00b67f09SDavid van Moolenbroek 	if (i >= maxbytes)
124*00b67f09SDavid van Moolenbroek 		strcpy(p, "...");
125*00b67f09SDavid van Moolenbroek 	else
126*00b67f09SDavid van Moolenbroek 		*p = '\0';
127*00b67f09SDavid van Moolenbroek 
128*00b67f09SDavid van Moolenbroek 	bufno = (bufno + 1) % STRING_NBUFS;
129*00b67f09SDavid van Moolenbroek 	return (buf);
130*00b67f09SDavid van Moolenbroek }
131*00b67f09SDavid van Moolenbroek 
132*00b67f09SDavid van Moolenbroek char *
idn__debug_ucs4xstring(const unsigned long * s,int maxbytes)133*00b67f09SDavid van Moolenbroek idn__debug_ucs4xstring(const unsigned long *s, int maxbytes) {
134*00b67f09SDavid van Moolenbroek 	char *buf = bufs[bufno];
135*00b67f09SDavid van Moolenbroek 	char *p;
136*00b67f09SDavid van Moolenbroek 	int i;
137*00b67f09SDavid van Moolenbroek 
138*00b67f09SDavid van Moolenbroek 	if (maxbytes > STRING_MAXBYTES)
139*00b67f09SDavid van Moolenbroek 		maxbytes = STRING_MAXBYTES;
140*00b67f09SDavid van Moolenbroek 
141*00b67f09SDavid van Moolenbroek 	i = 0;
142*00b67f09SDavid van Moolenbroek 	p = buf;
143*00b67f09SDavid van Moolenbroek 	while (i < maxbytes) {
144*00b67f09SDavid van Moolenbroek 		if (*s == '\0') {
145*00b67f09SDavid van Moolenbroek 			break;
146*00b67f09SDavid van Moolenbroek 		} else if (0x20 <= *s && *s <= 0x7e) {
147*00b67f09SDavid van Moolenbroek 			*p++ = *s;
148*00b67f09SDavid van Moolenbroek 			i++;
149*00b67f09SDavid van Moolenbroek 		} else {
150*00b67f09SDavid van Moolenbroek 			*p++ = '\\';
151*00b67f09SDavid van Moolenbroek 			*p++ = 'x';
152*00b67f09SDavid van Moolenbroek 			i += 2;
153*00b67f09SDavid van Moolenbroek 			if (*s >= 0x1000000UL) {
154*00b67f09SDavid van Moolenbroek 				*p++ = hex[(*s >> 28) & 0x0f];
155*00b67f09SDavid van Moolenbroek 				*p++ = hex[(*s >> 24) & 0x0f];
156*00b67f09SDavid van Moolenbroek 				i += 2;
157*00b67f09SDavid van Moolenbroek 			}
158*00b67f09SDavid van Moolenbroek 			if (*s >= 0x10000UL) {
159*00b67f09SDavid van Moolenbroek 				*p++ = hex[(*s >> 20) & 0x0f];
160*00b67f09SDavid van Moolenbroek 				*p++ = hex[(*s >> 16) & 0x0f];
161*00b67f09SDavid van Moolenbroek 				i += 2;
162*00b67f09SDavid van Moolenbroek 		    	}
163*00b67f09SDavid van Moolenbroek 			if (*s >= 0x100UL) {
164*00b67f09SDavid van Moolenbroek 				*p++ = hex[(*s >> 12) & 0x0f];
165*00b67f09SDavid van Moolenbroek 				*p++ = hex[(*s >>  8) & 0x0f];
166*00b67f09SDavid van Moolenbroek 				i += 2;
167*00b67f09SDavid van Moolenbroek 			}
168*00b67f09SDavid van Moolenbroek 			*p++ = hex[(*s >> 4) & 0x0f];
169*00b67f09SDavid van Moolenbroek 			*p++ = hex[ *s       & 0x0f];
170*00b67f09SDavid van Moolenbroek 			i += 2;
171*00b67f09SDavid van Moolenbroek 		}
172*00b67f09SDavid van Moolenbroek 		s++;
173*00b67f09SDavid van Moolenbroek 	}
174*00b67f09SDavid van Moolenbroek 
175*00b67f09SDavid van Moolenbroek 	if (i >= maxbytes)
176*00b67f09SDavid van Moolenbroek 		strcpy(p, "...");
177*00b67f09SDavid van Moolenbroek 	else
178*00b67f09SDavid van Moolenbroek 		*p = '\0';
179*00b67f09SDavid van Moolenbroek 
180*00b67f09SDavid van Moolenbroek 	bufno = (bufno + 1) % STRING_NBUFS;
181*00b67f09SDavid van Moolenbroek 	return (buf);
182*00b67f09SDavid van Moolenbroek }
183*00b67f09SDavid van Moolenbroek 
184*00b67f09SDavid van Moolenbroek char *
idn__debug_utf16xstring(const unsigned short * s,int maxbytes)185*00b67f09SDavid van Moolenbroek idn__debug_utf16xstring(const unsigned short *s, int maxbytes) {
186*00b67f09SDavid van Moolenbroek 	char *buf = bufs[bufno];
187*00b67f09SDavid van Moolenbroek 	char *p;
188*00b67f09SDavid van Moolenbroek 	int i;
189*00b67f09SDavid van Moolenbroek 
190*00b67f09SDavid van Moolenbroek 	if (maxbytes > STRING_MAXBYTES)
191*00b67f09SDavid van Moolenbroek 		maxbytes = STRING_MAXBYTES;
192*00b67f09SDavid van Moolenbroek 
193*00b67f09SDavid van Moolenbroek 	i = 0;
194*00b67f09SDavid van Moolenbroek 	p = buf;
195*00b67f09SDavid van Moolenbroek 	while (i < maxbytes) {
196*00b67f09SDavid van Moolenbroek 		if (*s == '\0') {
197*00b67f09SDavid van Moolenbroek 			break;
198*00b67f09SDavid van Moolenbroek 		} else if (0x20 <= *s && *s <= 0x7e) {
199*00b67f09SDavid van Moolenbroek 			*p++ = *s;
200*00b67f09SDavid van Moolenbroek 			i++;
201*00b67f09SDavid van Moolenbroek 		} else {
202*00b67f09SDavid van Moolenbroek 			*p++ = '\\';
203*00b67f09SDavid van Moolenbroek 			*p++ = 'x';
204*00b67f09SDavid van Moolenbroek 			*p++ = hex[(*s >> 12) & 0x0f];
205*00b67f09SDavid van Moolenbroek 			*p++ = hex[(*s >>  8) & 0x0f];
206*00b67f09SDavid van Moolenbroek 			*p++ = hex[(*s >> 4)  & 0x0f];
207*00b67f09SDavid van Moolenbroek 			*p++ = hex[ *s        & 0x0f];
208*00b67f09SDavid van Moolenbroek 			i += 6;
209*00b67f09SDavid van Moolenbroek 		}
210*00b67f09SDavid van Moolenbroek 		s++;
211*00b67f09SDavid van Moolenbroek 	}
212*00b67f09SDavid van Moolenbroek 
213*00b67f09SDavid van Moolenbroek 	if (i >= maxbytes)
214*00b67f09SDavid van Moolenbroek 		strcpy(p, "...");
215*00b67f09SDavid van Moolenbroek 	else
216*00b67f09SDavid van Moolenbroek 		*p = '\0';
217*00b67f09SDavid van Moolenbroek 
218*00b67f09SDavid van Moolenbroek 	bufno = (bufno + 1) % STRING_NBUFS;
219*00b67f09SDavid van Moolenbroek 	return (buf);
220*00b67f09SDavid van Moolenbroek }
221*00b67f09SDavid van Moolenbroek 
222*00b67f09SDavid van Moolenbroek char *
idn__debug_hexdata(const char * s,int length,int maxbytes)223*00b67f09SDavid van Moolenbroek idn__debug_hexdata(const char *s, int length, int maxbytes) {
224*00b67f09SDavid van Moolenbroek 	char *buf = bufs[bufno];
225*00b67f09SDavid van Moolenbroek 	char *p;
226*00b67f09SDavid van Moolenbroek 	int i;
227*00b67f09SDavid van Moolenbroek 
228*00b67f09SDavid van Moolenbroek 	if (maxbytes > STRING_MAXBYTES)
229*00b67f09SDavid van Moolenbroek 		maxbytes = STRING_MAXBYTES;
230*00b67f09SDavid van Moolenbroek 
231*00b67f09SDavid van Moolenbroek 	i = 0;
232*00b67f09SDavid van Moolenbroek 	p = buf;
233*00b67f09SDavid van Moolenbroek 	while (length > 0 && i < maxbytes) {
234*00b67f09SDavid van Moolenbroek 		int c = *(const unsigned char *)s;
235*00b67f09SDavid van Moolenbroek 
236*00b67f09SDavid van Moolenbroek 		*p++ = hex[c >> 4];
237*00b67f09SDavid van Moolenbroek 		*p++ = hex[c & 15];
238*00b67f09SDavid van Moolenbroek 		*p++ = ' ';
239*00b67f09SDavid van Moolenbroek 		i += 3;
240*00b67f09SDavid van Moolenbroek 		length--;
241*00b67f09SDavid van Moolenbroek 		s++;
242*00b67f09SDavid van Moolenbroek 	}
243*00b67f09SDavid van Moolenbroek 
244*00b67f09SDavid van Moolenbroek 	if (i >= maxbytes)
245*00b67f09SDavid van Moolenbroek 		strcpy(p, "...");
246*00b67f09SDavid van Moolenbroek 	else
247*00b67f09SDavid van Moolenbroek 		*p = '\0';
248*00b67f09SDavid van Moolenbroek 
249*00b67f09SDavid van Moolenbroek 	bufno = (bufno + 1) % STRING_NBUFS;
250*00b67f09SDavid van Moolenbroek 	return (buf);
251*00b67f09SDavid van Moolenbroek }
252*00b67f09SDavid van Moolenbroek 
253*00b67f09SDavid van Moolenbroek void
idn__debug_hexdump(const char * s,int length)254*00b67f09SDavid van Moolenbroek idn__debug_hexdump(const char *s, int length) {
255*00b67f09SDavid van Moolenbroek 	int i;
256*00b67f09SDavid van Moolenbroek 	const unsigned char *p = (const unsigned char *)s;
257*00b67f09SDavid van Moolenbroek 
258*00b67f09SDavid van Moolenbroek 	i = 0;
259*00b67f09SDavid van Moolenbroek 	while (length-- > 0) {
260*00b67f09SDavid van Moolenbroek 		if (i % 16 == 0) {
261*00b67f09SDavid van Moolenbroek 			if (i > 0)
262*00b67f09SDavid van Moolenbroek 				fprintf(stderr, "\n");
263*00b67f09SDavid van Moolenbroek 			fprintf(stderr, "%4x:", i);
264*00b67f09SDavid van Moolenbroek 		}
265*00b67f09SDavid van Moolenbroek 		fprintf(stderr, " %02x", p[i]);
266*00b67f09SDavid van Moolenbroek 		i++;
267*00b67f09SDavid van Moolenbroek 	}
268*00b67f09SDavid van Moolenbroek 	fprintf(stderr, "\n");
269*00b67f09SDavid van Moolenbroek }
270