#define FOUND -1
static int
-write_sharp_eq(object *vp,bool dot) {
+do_write_sharp_eq(object x,bool dot) {
- bool defined=vp[1]!=Cnil;
+ bool defined=x->c.c_cdr!=Cnil;
if (dot) {
write_str(" . ");
if (!defined) return FOUND;
}
- vp[1]=Ct;
+ x->c.c_cdr=Ct;
write_ch('#');
- write_decimal((vp-PRINTvs_top)/2);
+ write_decimal(fix(x->c.c_car));
write_ch(defined ? '#' : '=');
return defined ? DONE : FOUND;
}
static int
-write_sharp_eqs(object x,bool dot) {
+write_sharp_eq(object x,bool dot) {
- object *vp;
+ struct htent *e;
- for (vp = PRINTvs_top; vp < PRINTvs_limit; vp += 2)
- if (x == *vp)
- return write_sharp_eq(vp,dot);
-
- return 0;
+ return PRINTvs_top[0]!=Cnil && (e=gethash(x,PRINTvs_top[0]))->hte_key!=OBJNULL ?
+ do_write_sharp_eq(e->hte_value,dot) : 0;
}
if (PRINTescape) {
if (x->s.s_hpack == Cnil) {
if (PRINTcircle)
- if (write_sharp_eqs(x,FALSE)==DONE) return;
+ if (write_sharp_eq(x,FALSE)==DONE) return;
if (PRINTgensym)
write_str("#:");
} else if (x->s.s_hpack == keyword_package) {
break;
}
if (PRINTcircle)
- if (write_sharp_eqs(x,FALSE)==DONE) return;
+ if (write_sharp_eq(x,FALSE)==DONE) return;
if (PRINTlevel >= 0 && level >= PRINTlevel) {
write_ch('#');
break;
break;
}
if (PRINTcircle)
- if (write_sharp_eqs(x,FALSE)==DONE) return;
+ if (write_sharp_eq(x,FALSE)==DONE) return;
if (PRINTlevel >= 0 && level >= PRINTlevel) {
write_ch('#');
break;
break;
}
if (PRINTcircle)
- if (write_sharp_eqs(x,FALSE)==DONE) return;
+ if (write_sharp_eq(x,FALSE)==DONE) return;
if (PRINTpretty) {
if (x->c.c_car == sLquote &&
type_of(x->c.c_cdr) == t_cons &&
break;
}
if (PRINTcircle)
- switch (write_sharp_eqs(x,TRUE)) {
+ switch (write_sharp_eq(x,TRUE)) {
case FOUND:
write_object(x, level);
case DONE:
case t_structure:
if (PRINTcircle)
- if (write_sharp_eqs(x,FALSE)==DONE) return;
+ if (write_sharp_eq(x,FALSE)==DONE) return;
if (PRINTlevel >= 0 && level >= PRINTlevel) {
write_ch('#');
break;
if (!travel_pushed(x)) {
vs_check_push(x);
- vs_check_push(Cnil);
travel_pushed(x)=1;
}
}
+object sLeq;
static void
setupPRINTcircle(object x,int dogensyms) {
+ object *xp;
+
BEGIN_NO_INTERRUPT;
dgs=dogensyms;
travel_push(x);
travel_clear(x);
END_NO_INTERRUPT;
+ vs_check_push(PRINTvs_limit>PRINTvs_top ? funcall_cfun(Lmake_hash_table,2,sKtest,sLeq) : Cnil);
+ for (xp=PRINTvs_top;xp<PRINTvs_limit;xp++)
+ sethash(*xp,vs_head,MMcons(make_fixnum(xp-PRINTvs_top),Cnil));
+ PRINTvs_top[0]=vs_head;
+ PRINTvs_limit=vs_top=PRINTvs_top+1;
+
}
void