7 fmtinstall('A', Aconv);
8 fmtinstall('D', Dconv);
9 fmtinstall('P', Pconv);
10 fmtinstall('S', Sconv);
11 fmtinstall('N', Nconv);
27 p = va_arg(fp->args, Prog*);
31 sprint(str, "(%ld) %A %D/%d,%D",
32 p->line, a, &p->from, p->reg, &p->to);
35 sprint(str, "(%ld) %A %D,%D",
36 p->line, a, &p->from, &p->to);
38 if(p->from.type != D_FREG)
39 sprint(str, "(%ld) %A %D,R%d,%D",
40 p->line, a, &p->from, p->reg, &p->to);
42 sprint(str, "(%ld) %A %D,F%d,%D",
43 p->line, a, &p->from, p->reg, &p->to);
44 return fmtstrcpy(fp, str);
53 a = va_arg(fp->args, int);
55 if(a >= AXXX && a <= AEND)
57 return fmtstrcpy(fp, s);
67 a = va_arg(fp->args, Adr*);
71 sprint(str, "GOK-type(%d)", a->type);
76 if(a->name != D_NONE || a->reg != NREG || a->sym != S)
77 sprint(str, "%N(R%d)(NONE)", a, a->reg);
81 sprint(str, "$%N", a);
83 sprint(str, "%N(R%d)(CONST)", a, a->reg);
88 sprint(str, "%N(R%d)", a, a->reg);
94 sprint(str, "R%d", a->reg);
95 if(a->name != D_NONE || a->sym != S)
96 sprint(str, "%N(R%d)(REG)", a, a->reg);
100 sprint(str, "P%d", a->reg & 255);
101 if(a->name != D_NONE || a->sym != S)
102 sprint(str, "%N(R%d)(PREG)", a, a->reg);
106 sprint(str, "F%d", a->reg);
107 if(a->name != D_NONE || a->sym != S)
108 sprint(str, "%N(R%d)(FREG)", a, a->reg);
113 if(a->name != D_NONE || a->sym != S)
114 sprint(str, "%N(R%d)(FCREG)", a, a->reg);
117 case D_BRANCH: /* botch */
118 if(curp->cond != P) {
123 sprint(str, "%s+%.5lux(BRANCH)", a->sym->name, v);
125 sprint(str, "%.5lux(BRANCH)", v);
128 sprint(str, "%s+%lld(APC)", a->sym->name, a->offset);
130 sprint(str, "%lld(APC)", a->offset);
134 sprint(str, "$%e", ieeedtod(a->ieee));
138 sprint(str, "$\"%S\"", a->sval);
141 return fmtstrcpy(fp, str);
151 a = va_arg(fp->args, Adr*);
154 sprint(str, "%lld", a->offset);
159 sprint(str, "GOK-name(%d)", a->name);
163 sprint(str, "%lld", a->offset);
167 sprint(str, "%s+%lld(SB)", s->name, a->offset);
171 sprint(str, "%s<>+%lld(SB)", s->name, a->offset);
175 sprint(str, "%s-%lld(SP)", s->name, -a->offset);
179 sprint(str, "%s+%lld(FP)", s->name, a->offset);
183 return fmtstrcpy(fp, str);
190 char str[STRINGSZ], *p, *a;
192 a = va_arg(fp->args, char*);
194 for(i=0; i<sizeof(long); i++) {
196 if(c >= 'a' && c <= 'z' ||
197 c >= 'A' && c <= 'Z' ||
198 c >= '0' && c <= '9' ||
199 c == ' ' || c == '%') {
220 *p++ = ((c>>3) & 7) + '0';
221 *p++ = (c & 7) + '0';
224 return fmtstrcpy(fp, str);
230 char buf[STRINGSZ], *tn;
234 if(curtext != P && curtext->from.sym != S)
235 tn = curtext->from.sym->name;
237 vseprint(buf, buf+sizeof(buf), fmt, arg);
239 print("%s: %s\n", tn, buf);
243 print("too many errors\n");