xref: /minix3/external/bsd/bind/dist/lib/isccc/alist.c (revision 00b67f09dd46474d133c95011a48590a8e8f94c7)
1*00b67f09SDavid van Moolenbroek /*	$NetBSD: alist.c,v 1.4 2014/12/10 04:38:01 christos Exp $	*/
2*00b67f09SDavid van Moolenbroek 
3*00b67f09SDavid van Moolenbroek /*
4*00b67f09SDavid van Moolenbroek  * Portions Copyright (C) 2004, 2005, 2007  Internet Systems Consortium, Inc. ("ISC")
5*00b67f09SDavid van Moolenbroek  * Portions Copyright (C) 2001  Internet Software Consortium.
6*00b67f09SDavid van Moolenbroek  *
7*00b67f09SDavid van Moolenbroek  * Permission to use, copy, modify, and/or distribute this software for any
8*00b67f09SDavid van Moolenbroek  * purpose with or without fee is hereby granted, provided that the above
9*00b67f09SDavid van Moolenbroek  * copyright notice and this permission notice appear in all copies.
10*00b67f09SDavid van Moolenbroek  *
11*00b67f09SDavid van Moolenbroek  * THE SOFTWARE IS PROVIDED "AS IS" AND ISC AND NOMINUM DISCLAIMS ALL
12*00b67f09SDavid van Moolenbroek  * WARRANTIES WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES
13*00b67f09SDavid van Moolenbroek  * OF MERCHANTABILITY AND FITNESS.  IN NO EVENT SHALL ISC BE LIABLE FOR ANY
14*00b67f09SDavid van Moolenbroek  * SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
15*00b67f09SDavid van Moolenbroek  * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
16*00b67f09SDavid van Moolenbroek  * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
17*00b67f09SDavid van Moolenbroek  * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
18*00b67f09SDavid van Moolenbroek  *
19*00b67f09SDavid van Moolenbroek  * Portions Copyright (C) 2001  Nominum, Inc.
20*00b67f09SDavid van Moolenbroek  *
21*00b67f09SDavid van Moolenbroek  * Permission to use, copy, modify, and/or distribute this software for any
22*00b67f09SDavid van Moolenbroek  * purpose with or without fee is hereby granted, provided that the above
23*00b67f09SDavid van Moolenbroek  * copyright notice and this permission notice appear in all copies.
24*00b67f09SDavid van Moolenbroek  *
25*00b67f09SDavid van Moolenbroek  * THE SOFTWARE IS PROVIDED "AS IS" AND ISC AND NOMINUM DISCLAIMS ALL
26*00b67f09SDavid van Moolenbroek  * WARRANTIES WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES
27*00b67f09SDavid van Moolenbroek  * OF MERCHANTABILITY AND FITNESS.  IN NO EVENT SHALL ISC BE LIABLE FOR ANY
28*00b67f09SDavid van Moolenbroek  * SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
29*00b67f09SDavid van Moolenbroek  * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
30*00b67f09SDavid van Moolenbroek  * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
31*00b67f09SDavid van Moolenbroek  * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
32*00b67f09SDavid van Moolenbroek  */
33*00b67f09SDavid van Moolenbroek 
34*00b67f09SDavid van Moolenbroek /* Id: alist.c,v 1.8 2007/08/28 07:20:43 tbox Exp  */
35*00b67f09SDavid van Moolenbroek 
36*00b67f09SDavid van Moolenbroek /*! \file */
37*00b67f09SDavid van Moolenbroek 
38*00b67f09SDavid van Moolenbroek #include <config.h>
39*00b67f09SDavid van Moolenbroek 
40*00b67f09SDavid van Moolenbroek #include <stdlib.h>
41*00b67f09SDavid van Moolenbroek #include <string.h>
42*00b67f09SDavid van Moolenbroek 
43*00b67f09SDavid van Moolenbroek #include <isccc/alist.h>
44*00b67f09SDavid van Moolenbroek #include <isc/assertions.h>
45*00b67f09SDavid van Moolenbroek #include <isccc/result.h>
46*00b67f09SDavid van Moolenbroek #include <isccc/sexpr.h>
47*00b67f09SDavid van Moolenbroek #include <isccc/util.h>
48*00b67f09SDavid van Moolenbroek 
49*00b67f09SDavid van Moolenbroek #define CAR(s)			(s)->value.as_dottedpair.car
50*00b67f09SDavid van Moolenbroek #define CDR(s)			(s)->value.as_dottedpair.cdr
51*00b67f09SDavid van Moolenbroek 
52*00b67f09SDavid van Moolenbroek #define ALIST_TAG		"*alist*"
53*00b67f09SDavid van Moolenbroek #define MAX_INDENT		64
54*00b67f09SDavid van Moolenbroek 
55*00b67f09SDavid van Moolenbroek static char spaces[MAX_INDENT + 1] =
56*00b67f09SDavid van Moolenbroek 	"                                                                ";
57*00b67f09SDavid van Moolenbroek 
58*00b67f09SDavid van Moolenbroek isccc_sexpr_t *
isccc_alist_create(void)59*00b67f09SDavid van Moolenbroek isccc_alist_create(void)
60*00b67f09SDavid van Moolenbroek {
61*00b67f09SDavid van Moolenbroek 	isccc_sexpr_t *alist, *tag;
62*00b67f09SDavid van Moolenbroek 
63*00b67f09SDavid van Moolenbroek 	tag = isccc_sexpr_fromstring(ALIST_TAG);
64*00b67f09SDavid van Moolenbroek 	if (tag == NULL)
65*00b67f09SDavid van Moolenbroek 		return (NULL);
66*00b67f09SDavid van Moolenbroek 	alist = isccc_sexpr_cons(tag, NULL);
67*00b67f09SDavid van Moolenbroek 	if (alist == NULL) {
68*00b67f09SDavid van Moolenbroek 		isccc_sexpr_free(&tag);
69*00b67f09SDavid van Moolenbroek 		return (NULL);
70*00b67f09SDavid van Moolenbroek 	}
71*00b67f09SDavid van Moolenbroek 
72*00b67f09SDavid van Moolenbroek 	return (alist);
73*00b67f09SDavid van Moolenbroek }
74*00b67f09SDavid van Moolenbroek 
75*00b67f09SDavid van Moolenbroek isc_boolean_t
isccc_alist_alistp(isccc_sexpr_t * alist)76*00b67f09SDavid van Moolenbroek isccc_alist_alistp(isccc_sexpr_t *alist)
77*00b67f09SDavid van Moolenbroek {
78*00b67f09SDavid van Moolenbroek 	isccc_sexpr_t *car;
79*00b67f09SDavid van Moolenbroek 
80*00b67f09SDavid van Moolenbroek 	if (alist == NULL || alist->type != ISCCC_SEXPRTYPE_DOTTEDPAIR)
81*00b67f09SDavid van Moolenbroek 		return (ISC_FALSE);
82*00b67f09SDavid van Moolenbroek 	car = CAR(alist);
83*00b67f09SDavid van Moolenbroek 	if (car == NULL || car->type != ISCCC_SEXPRTYPE_STRING)
84*00b67f09SDavid van Moolenbroek 		return (ISC_FALSE);
85*00b67f09SDavid van Moolenbroek 	if (strcmp(car->value.as_string, ALIST_TAG) != 0)
86*00b67f09SDavid van Moolenbroek 		return (ISC_FALSE);
87*00b67f09SDavid van Moolenbroek 	return (ISC_TRUE);
88*00b67f09SDavid van Moolenbroek }
89*00b67f09SDavid van Moolenbroek 
90*00b67f09SDavid van Moolenbroek isc_boolean_t
isccc_alist_emptyp(isccc_sexpr_t * alist)91*00b67f09SDavid van Moolenbroek isccc_alist_emptyp(isccc_sexpr_t *alist)
92*00b67f09SDavid van Moolenbroek {
93*00b67f09SDavid van Moolenbroek 	REQUIRE(isccc_alist_alistp(alist));
94*00b67f09SDavid van Moolenbroek 
95*00b67f09SDavid van Moolenbroek 	if (CDR(alist) == NULL)
96*00b67f09SDavid van Moolenbroek 		return (ISC_TRUE);
97*00b67f09SDavid van Moolenbroek 	return (ISC_FALSE);
98*00b67f09SDavid van Moolenbroek }
99*00b67f09SDavid van Moolenbroek 
100*00b67f09SDavid van Moolenbroek isccc_sexpr_t *
isccc_alist_first(isccc_sexpr_t * alist)101*00b67f09SDavid van Moolenbroek isccc_alist_first(isccc_sexpr_t *alist)
102*00b67f09SDavid van Moolenbroek {
103*00b67f09SDavid van Moolenbroek 	REQUIRE(isccc_alist_alistp(alist));
104*00b67f09SDavid van Moolenbroek 
105*00b67f09SDavid van Moolenbroek 	return (CDR(alist));
106*00b67f09SDavid van Moolenbroek }
107*00b67f09SDavid van Moolenbroek 
108*00b67f09SDavid van Moolenbroek isccc_sexpr_t *
isccc_alist_assq(isccc_sexpr_t * alist,const char * key)109*00b67f09SDavid van Moolenbroek isccc_alist_assq(isccc_sexpr_t *alist, const char *key)
110*00b67f09SDavid van Moolenbroek {
111*00b67f09SDavid van Moolenbroek 	isccc_sexpr_t *car, *caar;
112*00b67f09SDavid van Moolenbroek 
113*00b67f09SDavid van Moolenbroek 	REQUIRE(isccc_alist_alistp(alist));
114*00b67f09SDavid van Moolenbroek 
115*00b67f09SDavid van Moolenbroek 	/*
116*00b67f09SDavid van Moolenbroek 	 * Skip alist type tag.
117*00b67f09SDavid van Moolenbroek 	 */
118*00b67f09SDavid van Moolenbroek 	alist = CDR(alist);
119*00b67f09SDavid van Moolenbroek 
120*00b67f09SDavid van Moolenbroek 	while (alist != NULL) {
121*00b67f09SDavid van Moolenbroek 		INSIST(alist->type == ISCCC_SEXPRTYPE_DOTTEDPAIR);
122*00b67f09SDavid van Moolenbroek 		car = CAR(alist);
123*00b67f09SDavid van Moolenbroek 		INSIST(car->type == ISCCC_SEXPRTYPE_DOTTEDPAIR);
124*00b67f09SDavid van Moolenbroek 		caar = CAR(car);
125*00b67f09SDavid van Moolenbroek 		if (caar->type == ISCCC_SEXPRTYPE_STRING &&
126*00b67f09SDavid van Moolenbroek 		    strcmp(caar->value.as_string, key) == 0)
127*00b67f09SDavid van Moolenbroek 			return (car);
128*00b67f09SDavid van Moolenbroek 		alist = CDR(alist);
129*00b67f09SDavid van Moolenbroek 	}
130*00b67f09SDavid van Moolenbroek 
131*00b67f09SDavid van Moolenbroek 	return (NULL);
132*00b67f09SDavid van Moolenbroek }
133*00b67f09SDavid van Moolenbroek 
134*00b67f09SDavid van Moolenbroek void
isccc_alist_delete(isccc_sexpr_t * alist,const char * key)135*00b67f09SDavid van Moolenbroek isccc_alist_delete(isccc_sexpr_t *alist, const char *key)
136*00b67f09SDavid van Moolenbroek {
137*00b67f09SDavid van Moolenbroek 	isccc_sexpr_t *car, *caar, *rest, *prev;
138*00b67f09SDavid van Moolenbroek 
139*00b67f09SDavid van Moolenbroek 	REQUIRE(isccc_alist_alistp(alist));
140*00b67f09SDavid van Moolenbroek 
141*00b67f09SDavid van Moolenbroek 	prev = alist;
142*00b67f09SDavid van Moolenbroek 	rest = CDR(alist);
143*00b67f09SDavid van Moolenbroek 	while (rest != NULL) {
144*00b67f09SDavid van Moolenbroek 		INSIST(rest->type == ISCCC_SEXPRTYPE_DOTTEDPAIR);
145*00b67f09SDavid van Moolenbroek 		car = CAR(rest);
146*00b67f09SDavid van Moolenbroek 		INSIST(car != NULL && car->type == ISCCC_SEXPRTYPE_DOTTEDPAIR);
147*00b67f09SDavid van Moolenbroek 		caar = CAR(car);
148*00b67f09SDavid van Moolenbroek 		if (caar->type == ISCCC_SEXPRTYPE_STRING &&
149*00b67f09SDavid van Moolenbroek 		    strcmp(caar->value.as_string, key) == 0) {
150*00b67f09SDavid van Moolenbroek 			CDR(prev) = CDR(rest);
151*00b67f09SDavid van Moolenbroek 			CDR(rest) = NULL;
152*00b67f09SDavid van Moolenbroek 			isccc_sexpr_free(&rest);
153*00b67f09SDavid van Moolenbroek 			break;
154*00b67f09SDavid van Moolenbroek 		}
155*00b67f09SDavid van Moolenbroek 		prev = rest;
156*00b67f09SDavid van Moolenbroek 		rest = CDR(rest);
157*00b67f09SDavid van Moolenbroek 	}
158*00b67f09SDavid van Moolenbroek }
159*00b67f09SDavid van Moolenbroek 
160*00b67f09SDavid van Moolenbroek isccc_sexpr_t *
isccc_alist_define(isccc_sexpr_t * alist,const char * key,isccc_sexpr_t * value)161*00b67f09SDavid van Moolenbroek isccc_alist_define(isccc_sexpr_t *alist, const char *key, isccc_sexpr_t *value)
162*00b67f09SDavid van Moolenbroek {
163*00b67f09SDavid van Moolenbroek 	isccc_sexpr_t *kv, *k, *elt;
164*00b67f09SDavid van Moolenbroek 
165*00b67f09SDavid van Moolenbroek 	kv = isccc_alist_assq(alist, key);
166*00b67f09SDavid van Moolenbroek 	if (kv == NULL) {
167*00b67f09SDavid van Moolenbroek 		/*
168*00b67f09SDavid van Moolenbroek 		 * New association.
169*00b67f09SDavid van Moolenbroek 		 */
170*00b67f09SDavid van Moolenbroek 		k = isccc_sexpr_fromstring(key);
171*00b67f09SDavid van Moolenbroek 		if (k == NULL)
172*00b67f09SDavid van Moolenbroek 			return (NULL);
173*00b67f09SDavid van Moolenbroek 		kv = isccc_sexpr_cons(k, value);
174*00b67f09SDavid van Moolenbroek 		if (kv == NULL) {
175*00b67f09SDavid van Moolenbroek 			isccc_sexpr_free(&kv);
176*00b67f09SDavid van Moolenbroek 			return (NULL);
177*00b67f09SDavid van Moolenbroek 		}
178*00b67f09SDavid van Moolenbroek 		elt = isccc_sexpr_addtolist(&alist, kv);
179*00b67f09SDavid van Moolenbroek 		if (elt == NULL) {
180*00b67f09SDavid van Moolenbroek 			isccc_sexpr_free(&kv);
181*00b67f09SDavid van Moolenbroek 			return (NULL);
182*00b67f09SDavid van Moolenbroek 		}
183*00b67f09SDavid van Moolenbroek 	} else {
184*00b67f09SDavid van Moolenbroek 		/*
185*00b67f09SDavid van Moolenbroek 		 * We've already got an entry for this key.  Replace it.
186*00b67f09SDavid van Moolenbroek 		 */
187*00b67f09SDavid van Moolenbroek 		isccc_sexpr_free(&CDR(kv));
188*00b67f09SDavid van Moolenbroek 		CDR(kv) = value;
189*00b67f09SDavid van Moolenbroek 	}
190*00b67f09SDavid van Moolenbroek 
191*00b67f09SDavid van Moolenbroek 	return (kv);
192*00b67f09SDavid van Moolenbroek }
193*00b67f09SDavid van Moolenbroek 
194*00b67f09SDavid van Moolenbroek isccc_sexpr_t *
isccc_alist_definestring(isccc_sexpr_t * alist,const char * key,const char * str)195*00b67f09SDavid van Moolenbroek isccc_alist_definestring(isccc_sexpr_t *alist, const char *key, const char *str)
196*00b67f09SDavid van Moolenbroek {
197*00b67f09SDavid van Moolenbroek 	isccc_sexpr_t *v, *kv;
198*00b67f09SDavid van Moolenbroek 
199*00b67f09SDavid van Moolenbroek 	v = isccc_sexpr_fromstring(str);
200*00b67f09SDavid van Moolenbroek 	if (v == NULL)
201*00b67f09SDavid van Moolenbroek 		return (NULL);
202*00b67f09SDavid van Moolenbroek 	kv = isccc_alist_define(alist, key, v);
203*00b67f09SDavid van Moolenbroek 	if (kv == NULL)
204*00b67f09SDavid van Moolenbroek 		isccc_sexpr_free(&v);
205*00b67f09SDavid van Moolenbroek 
206*00b67f09SDavid van Moolenbroek 	return (kv);
207*00b67f09SDavid van Moolenbroek }
208*00b67f09SDavid van Moolenbroek 
209*00b67f09SDavid van Moolenbroek isccc_sexpr_t *
isccc_alist_definebinary(isccc_sexpr_t * alist,const char * key,isccc_region_t * r)210*00b67f09SDavid van Moolenbroek isccc_alist_definebinary(isccc_sexpr_t *alist, const char *key, isccc_region_t *r)
211*00b67f09SDavid van Moolenbroek {
212*00b67f09SDavid van Moolenbroek 	isccc_sexpr_t *v, *kv;
213*00b67f09SDavid van Moolenbroek 
214*00b67f09SDavid van Moolenbroek 	v = isccc_sexpr_frombinary(r);
215*00b67f09SDavid van Moolenbroek 	if (v == NULL)
216*00b67f09SDavid van Moolenbroek 		return (NULL);
217*00b67f09SDavid van Moolenbroek 	kv = isccc_alist_define(alist, key, v);
218*00b67f09SDavid van Moolenbroek 	if (kv == NULL)
219*00b67f09SDavid van Moolenbroek 		isccc_sexpr_free(&v);
220*00b67f09SDavid van Moolenbroek 
221*00b67f09SDavid van Moolenbroek 	return (kv);
222*00b67f09SDavid van Moolenbroek }
223*00b67f09SDavid van Moolenbroek 
224*00b67f09SDavid van Moolenbroek isccc_sexpr_t *
isccc_alist_lookup(isccc_sexpr_t * alist,const char * key)225*00b67f09SDavid van Moolenbroek isccc_alist_lookup(isccc_sexpr_t *alist, const char *key)
226*00b67f09SDavid van Moolenbroek {
227*00b67f09SDavid van Moolenbroek 	isccc_sexpr_t *kv;
228*00b67f09SDavid van Moolenbroek 
229*00b67f09SDavid van Moolenbroek 	kv = isccc_alist_assq(alist, key);
230*00b67f09SDavid van Moolenbroek 	if (kv != NULL)
231*00b67f09SDavid van Moolenbroek 		return (CDR(kv));
232*00b67f09SDavid van Moolenbroek 	return (NULL);
233*00b67f09SDavid van Moolenbroek }
234*00b67f09SDavid van Moolenbroek 
235*00b67f09SDavid van Moolenbroek isc_result_t
isccc_alist_lookupstring(isccc_sexpr_t * alist,const char * key,char ** strp)236*00b67f09SDavid van Moolenbroek isccc_alist_lookupstring(isccc_sexpr_t *alist, const char *key, char **strp)
237*00b67f09SDavid van Moolenbroek {
238*00b67f09SDavid van Moolenbroek 	isccc_sexpr_t *kv, *v;
239*00b67f09SDavid van Moolenbroek 
240*00b67f09SDavid van Moolenbroek 	kv = isccc_alist_assq(alist, key);
241*00b67f09SDavid van Moolenbroek 	if (kv != NULL) {
242*00b67f09SDavid van Moolenbroek 		v = CDR(kv);
243*00b67f09SDavid van Moolenbroek 		if (isccc_sexpr_stringp(v)) {
244*00b67f09SDavid van Moolenbroek 			if (strp != NULL)
245*00b67f09SDavid van Moolenbroek 				*strp = isccc_sexpr_tostring(v);
246*00b67f09SDavid van Moolenbroek 			return (ISC_R_SUCCESS);
247*00b67f09SDavid van Moolenbroek 		} else
248*00b67f09SDavid van Moolenbroek 			return (ISC_R_EXISTS);
249*00b67f09SDavid van Moolenbroek 	}
250*00b67f09SDavid van Moolenbroek 
251*00b67f09SDavid van Moolenbroek 	return (ISC_R_NOTFOUND);
252*00b67f09SDavid van Moolenbroek }
253*00b67f09SDavid van Moolenbroek 
254*00b67f09SDavid van Moolenbroek isc_result_t
isccc_alist_lookupbinary(isccc_sexpr_t * alist,const char * key,isccc_region_t ** r)255*00b67f09SDavid van Moolenbroek isccc_alist_lookupbinary(isccc_sexpr_t *alist, const char *key, isccc_region_t **r)
256*00b67f09SDavid van Moolenbroek {
257*00b67f09SDavid van Moolenbroek 	isccc_sexpr_t *kv, *v;
258*00b67f09SDavid van Moolenbroek 
259*00b67f09SDavid van Moolenbroek 	kv = isccc_alist_assq(alist, key);
260*00b67f09SDavid van Moolenbroek 	if (kv != NULL) {
261*00b67f09SDavid van Moolenbroek 		v = CDR(kv);
262*00b67f09SDavid van Moolenbroek 		if (isccc_sexpr_binaryp(v)) {
263*00b67f09SDavid van Moolenbroek 			if (r != NULL)
264*00b67f09SDavid van Moolenbroek 				*r = isccc_sexpr_tobinary(v);
265*00b67f09SDavid van Moolenbroek 			return (ISC_R_SUCCESS);
266*00b67f09SDavid van Moolenbroek 		} else
267*00b67f09SDavid van Moolenbroek 			return (ISC_R_EXISTS);
268*00b67f09SDavid van Moolenbroek 	}
269*00b67f09SDavid van Moolenbroek 
270*00b67f09SDavid van Moolenbroek 	return (ISC_R_NOTFOUND);
271*00b67f09SDavid van Moolenbroek }
272*00b67f09SDavid van Moolenbroek 
273*00b67f09SDavid van Moolenbroek void
isccc_alist_prettyprint(isccc_sexpr_t * sexpr,unsigned int indent,FILE * stream)274*00b67f09SDavid van Moolenbroek isccc_alist_prettyprint(isccc_sexpr_t *sexpr, unsigned int indent, FILE *stream)
275*00b67f09SDavid van Moolenbroek {
276*00b67f09SDavid van Moolenbroek 	isccc_sexpr_t *elt, *kv, *k, *v;
277*00b67f09SDavid van Moolenbroek 
278*00b67f09SDavid van Moolenbroek 	if (isccc_alist_alistp(sexpr)) {
279*00b67f09SDavid van Moolenbroek 		fprintf(stream, "{\n");
280*00b67f09SDavid van Moolenbroek 		indent += 4;
281*00b67f09SDavid van Moolenbroek 		for (elt = isccc_alist_first(sexpr);
282*00b67f09SDavid van Moolenbroek 		     elt != NULL;
283*00b67f09SDavid van Moolenbroek 		     elt = CDR(elt)) {
284*00b67f09SDavid van Moolenbroek 			kv = CAR(elt);
285*00b67f09SDavid van Moolenbroek 			INSIST(isccc_sexpr_listp(kv));
286*00b67f09SDavid van Moolenbroek 			k = CAR(kv);
287*00b67f09SDavid van Moolenbroek 			v = CDR(kv);
288*00b67f09SDavid van Moolenbroek 			INSIST(isccc_sexpr_stringp(k));
289*00b67f09SDavid van Moolenbroek 			fprintf(stream, "%.*s%s => ", (int)indent, spaces,
290*00b67f09SDavid van Moolenbroek 				isccc_sexpr_tostring(k));
291*00b67f09SDavid van Moolenbroek 			isccc_alist_prettyprint(v, indent, stream);
292*00b67f09SDavid van Moolenbroek 			if (CDR(elt) != NULL)
293*00b67f09SDavid van Moolenbroek 				fprintf(stream, ",");
294*00b67f09SDavid van Moolenbroek 			fprintf(stream, "\n");
295*00b67f09SDavid van Moolenbroek 		}
296*00b67f09SDavid van Moolenbroek 		indent -= 4;
297*00b67f09SDavid van Moolenbroek 		fprintf(stream, "%.*s}", (int)indent, spaces);
298*00b67f09SDavid van Moolenbroek 	} else if (isccc_sexpr_listp(sexpr)) {
299*00b67f09SDavid van Moolenbroek 		fprintf(stream, "(\n");
300*00b67f09SDavid van Moolenbroek 		indent += 4;
301*00b67f09SDavid van Moolenbroek 		for (elt = sexpr;
302*00b67f09SDavid van Moolenbroek 		     elt != NULL;
303*00b67f09SDavid van Moolenbroek 		     elt = CDR(elt)) {
304*00b67f09SDavid van Moolenbroek 			fprintf(stream, "%.*s", (int)indent, spaces);
305*00b67f09SDavid van Moolenbroek 			isccc_alist_prettyprint(CAR(elt), indent, stream);
306*00b67f09SDavid van Moolenbroek 			if (CDR(elt) != NULL)
307*00b67f09SDavid van Moolenbroek 				fprintf(stream, ",");
308*00b67f09SDavid van Moolenbroek 			fprintf(stream, "\n");
309*00b67f09SDavid van Moolenbroek 		}
310*00b67f09SDavid van Moolenbroek 		indent -= 4;
311*00b67f09SDavid van Moolenbroek 		fprintf(stream, "%.*s)", (int)indent, spaces);
312*00b67f09SDavid van Moolenbroek 	} else
313*00b67f09SDavid van Moolenbroek 		isccc_sexpr_print(sexpr, stream);
314*00b67f09SDavid van Moolenbroek }
315