8 fmtinstall('A', Aconv);
9 fmtinstall('P', Pconv);
10 fmtinstall('S', Sconv);
11 fmtinstall('N', Nconv);
12 fmtinstall('D', Dconv);
13 fmtinstall('B', Bconv);
19 char str[STRINGSZ], ss[STRINGSZ], *s;
24 bits = va_arg(fp->args, Bits);
30 sprint(ss, "$%ld", var[i].offset);
34 if(strlen(str) + strlen(s) + 1 >= STRINGSZ)
37 bits.b[i/32] &= ~(1L << (i%32));
39 return fmtstrcpy(fp, str);
49 p = va_arg(fp->args, Prog*);
52 sprint(str, " %A %D/%d,%D", a, &p->from, p->reg, &p->to);
55 sprint(str, " %A %D,%d,%D", a, &p->from, p->reg, &p->to);
58 sprint(str, " %A %D,%D", a, &p->from, &p->to);
60 if(p->from.type != D_FREG)
61 sprint(str, " %A %D,R%d,%D", a, &p->from, p->reg, &p->to);
63 sprint(str, " %A %D,F%d,%D", a, &p->from, p->reg, &p->to);
64 return fmtstrcpy(fp, str);
73 a = va_arg(fp->args, int);
75 if(a >= AXXX && a <= AEND)
77 return fmtstrcpy(fp, s);
86 a = va_arg(fp->args, Adr*);
90 sprint(str, "GOK-type(%d)", a->type);
95 if(a->name != D_NONE || a->reg != NREG || a->sym != S)
96 sprint(str, "%N(R%d)(NONE)", a, a->reg);
101 sprint(str, "$%N(R%d)", a, a->reg);
103 sprint(str, "$%N", a);
108 sprint(str, "%N(R%d)", a, a->reg);
110 sprint(str, "%N", a);
114 sprint(str, "R%d", a->reg);
115 if(a->name != D_NONE || a->sym != S)
116 sprint(str, "%N(R%d)(REG)", a, a->reg);
120 sprint(str, "F%d", a->reg);
121 if(a->name != D_NONE || a->sym != S)
122 sprint(str, "%N(F%d)(REG)", a, a->reg);
126 sprint(str, "C%d", a->reg);
127 if(a->name != D_NONE || a->sym != S)
128 sprint(str, "%N(C%d)(REG)", a, a->reg);
132 sprint(str, "%ld(PC)", a->offset-pc);
136 sprint(str, "$%.17e", a->dval);
140 sprint(str, "$\"%S\"", a->sval);
143 return fmtstrcpy(fp, str);
150 char str[STRINGSZ], *p, *a;
152 a = va_arg(fp->args, char*);
154 for(i=0; i<NSNAME; i++) {
156 if(c >= 'a' && c <= 'z' ||
157 c >= 'A' && c <= 'Z' ||
158 c >= '0' && c <= '9' ||
159 c == ' ' || c == '%') {
186 *p++ = ((c>>3) & 7) + '0';
187 *p++ = (c & 7) + '0';
190 return fmtstrcpy(fp, str);
200 a = va_arg(fp->args, Adr*);
203 sprint(str, "%ld", a->offset);
208 sprint(str, "GOK-name(%d)", a->name);
212 sprint(str, "%s+%ld(SB)", s->name, a->offset);
216 sprint(str, "%s<>+%ld(SB)", s->name, a->offset);
220 sprint(str, "%s-%ld(SP)", s->name, -a->offset);
224 sprint(str, "%s+%ld(FP)", s->name, a->offset);
228 return fmtstrcpy(fp, str);