/* * (c) copyright 1990 by the Vrije Universiteit, Amsterdam, The Netherlands. * See the copyright notice in the ACK home directory, in the file "Copyright". * * Author: Ceriel J.H. Jacobs */ /* D E B U G G E R S Y M B O L T A B L E */ /* $Header$ */ #include #include #include #include #include #include "LLlex.h" #include "def.h" #include "type.h" #include "idf.h" #include "const.h" #include "scope.h" #include "main.h" #include "node.h" #define INCR_SIZE 64 extern int proclevel; static struct db_str { unsigned sz; char *base; char *currpos; } db_str; static create_db_str() { if (! db_str.base) { db_str.base = Malloc(INCR_SIZE); db_str.sz = INCR_SIZE; } db_str.currpos = db_str.base; } static addc_db_str(c) int c; { int df = db_str.currpos - db_str.base; if (df >= db_str.sz-1) { db_str.sz += INCR_SIZE; db_str.base = Realloc(db_str.base, db_str.sz); db_str.currpos = db_str.base + df; } *db_str.currpos++ = c; *db_str.currpos = '\0'; } static adds_db_str(s) char *s; { while (*s) addc_db_str(*s++); } static stb_type(tp, assign_num) register struct type *tp; { char buf[128]; static int stb_count; if (tp->tp_dbindex > 0) { adds_db_str(sprint(buf, "%d", tp->tp_dbindex)); return; } if (tp->tp_dbindex < 0) { if (tp->next == 0) { adds_db_str(sprint(buf, "%d", -tp->tp_dbindex)); return; } tp->tp_dbindex = -tp->tp_dbindex; } if (tp->tp_dbindex == 0 && assign_num) { tp->tp_dbindex = ++stb_count; } if (tp->tp_dbindex > 0) { adds_db_str(sprint(buf, "%d=", tp->tp_dbindex)); } if (tp == void_type) { adds_db_str(sprint(buf, "%d", tp->tp_dbindex)); return; } switch(tp->tp_fund) { /* simple types ... */ case T_INTEGER: case T_LONG: { arith l = full_mask[(int)tp->tp_size] & ~(1L << (tp->tp_size*8-1)); adds_db_str(sprint(buf, "r%d;%ld;%ld", tp->tp_dbindex, (long) -l-1, (long) l)); } break; case T_REAL: adds_db_str(sprint(buf, "r%d;%ld;0", tp->tp_dbindex, (long)tp->tp_size)); break; case T_CHAR: adds_db_str(sprint(buf, "r%d;0;255", tp->tp_dbindex)); break; /* constructed types ... */ case T_SUBRANGE: adds_db_str(sprint(buf, "r%d;%ld;%ld", tp->next->tp_dbindex, (long) tp->sub_lb, (long) tp->sub_ub)); break; case T_POINTER: if (tp->next) { addc_db_str('*'); stb_type(tp->next, 0); if (tp->tp_dbindex < 0) tp->tp_dbindex = -tp->tp_dbindex; } else { tp->tp_dbindex = - ++stb_count; adds_db_str(sprint(buf, "%d", -tp->tp_dbindex)); } break; case T_SET: addc_db_str('S'); stb_type(tp->next, 0); adds_db_str(sprint(buf, ";%ld;%ld;", tp->tp_size, 0L)); break; case T_ARRAY: addc_db_str('a'); if (IsConformantArray(tp)) { addc_db_str('r'); stb_type(tp->next, 0); adds_db_str(sprint(buf, ";A%ld;Z%ld", tp->arr_cfdescr, tp->arr_cfdescr)); } else { stb_type(tp->next, 0); } addc_db_str(';'); stb_type(tp->arr_elem, 0); break; case T_ENUMERATION: addc_db_str('e'); { register struct def *edef = tp->enm_enums; while (edef) { adds_db_str(sprint(buf, "%s:%ld,", edef->df_idf->id_text, edef->enm_val)); edef = edef->enm_next; } } addc_db_str(';'); break; case T_RECORD: adds_db_str(sprint(buf, "s%ld", tp->tp_size)); { register struct def *sdef = tp->rec_scope->sc_def; while (sdef) { adds_db_str(sdef->df_idf->id_text); addc_db_str(':'); stb_type(sdef->df_type, 0); adds_db_str(sprint(buf, ",%ld,%ld;", sdef->fld_off*8, sdef->df_type->tp_size*8)); sdef = sdef->df_nextinscope; } } addc_db_str(';'); break; case T_PROCEDURE: case T_FUNCTION: addc_db_str('Q'); stb_type(tp->next ? tp->next : void_type, 0); { register struct paramlist *p = tp->prc_params; int paramcount = 0; while (p) { paramcount++; p = p->next; } adds_db_str(sprint(buf, ",%d;", paramcount)); p = tp->prc_params; while (p) { addc_db_str(IsVarParam(p) ? 'v' : IsConformantArray(TypeOfParam(p)) ? 'i' : 'p'); stb_type(TypeOfParam(p), 0); addc_db_str(';'); p = p->next; } } break; case T_FILE: addc_db_str('L'); stb_type(tp->next); break; case T_STRING: addc_db_str('*'); stb_type(char_type); break; } } stb_string(df, kind) register struct def *df; { register struct type *tp = df->df_type; char buf[64]; create_db_str(); adds_db_str(df->df_idf->id_text); addc_db_str(':'); switch(kind) { case D_MODULE: adds_db_str(sprint(buf, "M%d;", df->prc_vis->sc_count)); C_ms_stb_pnam(db_str.base, N_FUN, proclevel, "m_a_i_n"); break; case D_PROCEDURE: case D_FUNCTION: adds_db_str(sprint(buf, "Q%d;", df->prc_vis->sc_count)); stb_type(tp->next ? tp->next : void_type, 0); addc_db_str(';'); C_ms_stb_pnam(db_str.base, N_FUN, proclevel, df->df_idf->id_text); { register struct paramlist *p = tp->prc_params; while (p) { stb_string(p->par_def, D_VARIABLE); p = p->next; } } for (df = df->prc_vis->sc_scope->sc_def; df; df = df->df_nextinscope) { if (df->df_kind == D_LBOUND || df->df_kind == D_UBOUND) { stb_string(df, df->df_kind); } } break; case D_END: case D_PEND: adds_db_str(sprint(buf, "E%d;", df->prc_vis->sc_count)); C_ms_stb_cst(db_str.base, N_SCOPE, proclevel, 0); break; case D_VARIABLE: if (df->df_flags & D_VARPAR) { /* VAR parameter */ addc_db_str('v'); stb_type(tp, 0); addc_db_str(';'); C_ms_stb_cst(db_str.base, N_PSYM, 0, df->var_off); } else if (df->df_flags & D_VALPAR) { /* value parameter */ addc_db_str(IsConformantArray(tp) ? 'i' : 'p'); stb_type(tp, 0); addc_db_str(';'); C_ms_stb_cst(db_str.base, N_PSYM, 0, df->var_off); } else if (!proclevel) { addc_db_str('G'); stb_type(tp, 0); addc_db_str(';'); C_ms_stb_dnam(db_str.base, N_LCSYM, 0, df->var_name, (arith) 0); } else { /* local variable */ stb_type(tp, 1); /* assign type num to avoid difficult to parse string */ addc_db_str(';'); C_ms_stb_cst(db_str.base, N_LSYM, 0, df->var_off); } break; case D_LBOUND: case D_UBOUND: addc_db_str(kind == D_LBOUND ? 'A' : 'Z'); addc_db_str('p'); stb_type(tp, 0); addc_db_str(';'); C_ms_stb_cst(db_str.base, N_PSYM, 0, df->bnd_type->arr_cfdescr); break; case D_TYPE: addc_db_str('t'); stb_type(tp, 1); addc_db_str(';'); C_ms_stb_cst(db_str.base, N_LSYM, tp == void_type || tp->tp_size > 32767 ? 0 : (int)tp->tp_size, (arith) 0); break; case D_CONST: addc_db_str('c'); addc_db_str('='); tp = BaseType(tp); switch(tp->tp_fund) { case T_INTEGER: case T_LONG: case T_POINTER: case T_PROCEDURE: adds_db_str(sprint(buf, "i%ld;", df->con_const->nd_INT)); break; case T_CHAR: adds_db_str(sprint(buf, "c%ld;", df->con_const->nd_INT)); break; case T_REAL: addc_db_str('r'); adds_db_str(df->con_const->nd_REL); addc_db_str(';'); break; case T_STRINGCONST: { register char *p = df->con_const->nd_STR; adds_db_str("s'"); while (*p) { if (*p == '\'' || *p == '\\') { addc_db_str('\\'); } addc_db_str(*p++); } adds_db_str("';"); } break; case T_ENUMERATION: addc_db_str('e'); stb_type(tp, 0); adds_db_str(sprint(buf, ",%ld;", df->enm_val)); break; case T_SET: { register int i; addc_db_str('S'); stb_type(tp, 0); for (i = 0; i < tp->tp_size; i++) { adds_db_str(sprint(buf, ",%ld", (df->con_const->nd_set[i/(int) word_size] >> (8*(i%(int)word_size)))&0377)); } addc_db_str(';'); } break; } C_ms_stb_cst(db_str.base, N_LSYM, tp->tp_size <= 32767 ? (int)tp->tp_size : 0, (arith) 0); break; } }