19674Slinton /* Copyright (c) 1982 Regents of the University of California */ 29674Slinton 3*11166Slinton static char sccsid[] = "@(#)operators.c 1.3 02/20/83"; 49674Slinton 59674Slinton /* 69674Slinton * Tree node classes. 79674Slinton */ 89674Slinton 99674Slinton #include "defs.h" 109674Slinton #include "operators.h" 119674Slinton 129674Slinton #ifndef public 139674Slinton typedef struct { 149674Slinton char numargs; 159674Slinton char opflags; 169674Slinton String opstring; 179674Slinton } Opinfo; 189674Slinton 199674Slinton typedef enum { 209674Slinton O_NOP, 219674Slinton O_NAME, O_SYM, O_LCON, O_FCON, O_SCON, 229674Slinton O_RVAL, O_INDEX, O_INDIR, O_DOT, 239674Slinton O_COMMA, 249674Slinton 259674Slinton O_ITOF, O_ADD, O_ADDF, O_SUB, O_SUBF, O_NEG, O_NEGF, 269674Slinton O_MUL, O_MULF, O_DIVF, O_DIV, O_MOD, 279674Slinton 289674Slinton O_AND, O_OR, 299674Slinton 309674Slinton O_LT, O_LTF, O_LE, O_LEF, O_GT, O_GTF, O_GE, O_GEF, 319674Slinton O_EQ, O_EQF, O_NE, O_NEF, 329674Slinton 339674Slinton O_ALIAS, /* rename a command */ 349674Slinton O_ASSIGN, /* assign a value to a program variable */ 359674Slinton O_CALL, /* call a procedure in the program */ 369674Slinton O_CATCH, /* catch a signal before program does */ 379674Slinton O_CHFILE, /* change (or print) the current source file */ 389674Slinton O_CONT, /* continue execution */ 399674Slinton O_DELETE, /* remove a trace/stop */ 409674Slinton O_DUMP, /* dump out variables */ 419674Slinton O_EDIT, /* edit a file (or function) */ 429674Slinton O_FUNC, /* set the current function */ 439674Slinton O_GRIPE, /* send mail to debugger support person */ 449674Slinton O_HELP, /* print a synopsis of debugger commands */ 459674Slinton O_IGNORE, /* let program catch signal */ 469674Slinton O_LIST, /* list source lines */ 479674Slinton O_PRINT, /* print the values of a list of expressions */ 489674Slinton O_PSYM, /* print symbol information */ 499674Slinton O_RUN, /* start up program */ 509674Slinton O_SKIP, /* skip the current line */ 519674Slinton O_SOURCE, /* read commands from a file */ 529674Slinton O_STATUS, /* display currently active trace/stop's */ 539674Slinton O_STEP, /* execute a single line */ 549674Slinton O_STOP, /* stop on an event */ 559674Slinton O_STOPI, /* stop on an event at an instruction boundary */ 569674Slinton O_TRACE, /* trace something on an event */ 579674Slinton O_TRACEI, /* trace at the instruction level */ 589674Slinton O_WHATIS, /* print the declaration of a variable */ 599674Slinton O_WHERE, /* print a stack trace */ 609674Slinton O_WHEREIS, /* print all the symbols with the given name */ 619674Slinton O_WHICH, /* print out full qualification of a symbol */ 629674Slinton O_EXAMINE, /* examine program instructions/data */ 639674Slinton 649674Slinton O_ADDEVENT, /* add an event */ 659674Slinton O_ENDX, /* end of program reached */ 669674Slinton O_IF, /* if first arg is true, do commands in second arg */ 679674Slinton O_ONCE, /* add a "one-time" event, delete when first reached */ 689674Slinton O_PRINTCALL, /* print out the current procedure and its arguments */ 699674Slinton O_PRINTIFCHANGED, /* print the value of the argument if it has changed */ 709674Slinton O_PRINTRTN, /* print out the routine and value that just returned */ 719674Slinton O_PRINTSRCPOS, /* print out the current source position */ 729674Slinton O_PROCRTN, /* CALLPROC completed */ 739674Slinton O_QLINE, /* filename, line number */ 749674Slinton O_STOPIFCHANGED, /* stop if the value of the argument has changed */ 759674Slinton O_STOPX, /* stop execution */ 769674Slinton O_TRACEON, /* begin tracing source line, variable, or all lines */ 779674Slinton O_TRACEOFF, /* end tracing source line, variable, or all lines */ 789674Slinton 79*11166Slinton O_TYPERENAME, /* state the type of an expression */ 80*11166Slinton 819674Slinton O_LASTOP 829674Slinton } Operator; 839674Slinton 849674Slinton /* 859674Slinton * Operator flags and predicates. 869674Slinton */ 879674Slinton 889674Slinton #define null 0 899674Slinton #define LEAF 01 909674Slinton #define UNARY 02 919674Slinton #define BINARY 04 929674Slinton #define BOOL 010 939674Slinton #define REALOP 020 949674Slinton #define INTOP 040 959674Slinton 969674Slinton #define isbitset(a, m) ((a&m) == m) 979674Slinton #define isleaf(o) isbitset(opinfo[ord(o)].opflags, LEAF) 989674Slinton #define isunary(o) isbitset(opinfo[ord(o)].opflags, UNARY) 999674Slinton #define isbinary(o) isbitset(opinfo[ord(o)].opflags, BINARY) 1009674Slinton #define isreal(o) isbitset(opinfo[ord(o)].opflags, REALOP) 1019674Slinton #define isint(o) isbitset(opinfo[ord(o)].opflags, INTOP) 1029674Slinton #define isboolean(o) isbitset(opinfo[ord(o)].opflags, BOOL) 1039674Slinton 1049674Slinton #define degree(o) (opinfo[ord(o)].opflags&(LEAF|UNARY|BINARY)) 1059674Slinton #define nargs(o) (opinfo[ord(o)].numargs) 1069674Slinton 1079674Slinton #endif 1089674Slinton 1099674Slinton /* 1109674Slinton * Operator information structure. 1119674Slinton */ 1129674Slinton 1139674Slinton public Opinfo opinfo[] ={ 1149674Slinton /* O_NOP */ 0, null, 0, 1159674Slinton /* O_NAME */ -1, LEAF, 0, 1169674Slinton /* O_SYM */ -1, LEAF, 0, 1179674Slinton /* O_LCON */ -1, LEAF, 0, 1189674Slinton /* O_FCON */ -1, LEAF, 0, 1199674Slinton /* O_SCON */ -1, LEAF, 0, 1209674Slinton /* O_RVAL */ 1, UNARY, 0, 1219674Slinton /* O_INDEX */ 2, BINARY, 0, 1229674Slinton /* O_INDIR */ 1, UNARY, "^", 1239674Slinton /* O_DOT */ 2, null, ".", 1249674Slinton /* O_COMMA */ 2, BINARY, ",", 1259674Slinton /* O_ITOF */ 1, UNARY|INTOP, 0, 1269674Slinton /* O_ADD */ 2, BINARY|INTOP, "+", 1279674Slinton /* O_ADDF */ 2, BINARY|REALOP, "+", 1289674Slinton /* O_SUB */ 2, BINARY|INTOP, "-", 1299674Slinton /* O_SUBF */ 2, BINARY|REALOP, "-", 1309674Slinton /* O_NEG */ 1, UNARY|INTOP, "-", 1319674Slinton /* O_NEGF */ 1, UNARY|REALOP, "-", 1329674Slinton /* O_MUL */ 2, BINARY|INTOP, "*", 1339674Slinton /* O_MULF */ 2, BINARY|REALOP, "*", 1349674Slinton /* O_DIVF */ 2, BINARY|REALOP, "/", 1359674Slinton /* O_DIV */ 2, BINARY|INTOP, " div ", 1369674Slinton /* O_MOD */ 2, BINARY|INTOP, " mod ", 1379674Slinton /* O_AND */ 2, BINARY|INTOP, " and ", 1389674Slinton /* O_OR */ 2, BINARY|INTOP, " or ", 1399674Slinton /* O_LT */ 2, BINARY|INTOP, " < ", 1409674Slinton /* O_LTF */ 2, BINARY|REALOP, " < ", 1419674Slinton /* O_LE */ 2, BINARY|INTOP, " <= ", 1429674Slinton /* O_LEF */ 2, BINARY|REALOP, " <= ", 1439674Slinton /* O_GT */ 2, BINARY|INTOP, " > ", 1449674Slinton /* O_GTF */ 2, BINARY|REALOP, " > ", 1459674Slinton /* O_GE */ 2, BINARY|INTOP, " >= ", 1469674Slinton /* O_GEF */ 2, BINARY|REALOP, " >= ", 1479674Slinton /* O_EQ */ 2, BINARY|INTOP, " = ", 1489674Slinton /* O_EQF */ 2, BINARY|REALOP, " = ", 1499674Slinton /* O_NE */ 2, BINARY|INTOP, " <> ", 1509674Slinton /* O_NEF */ 2, BINARY|REALOP, " <> ", 1519674Slinton 1529674Slinton /* O_ALIAS */ 2, null, "alias", 1539674Slinton /* O_ASSIGN */ 2, BINARY, " := ", 1549674Slinton /* O_CALL */ 2, null, "call", 1559674Slinton /* O_CATCH */ 0, null, "catch", 1569674Slinton /* O_CHFILE */ 0, null, "file", 1579674Slinton /* O_CONT */ 0, null, "cont", 1589674Slinton /* O_DELETE */ 0, null, "delete", 1599674Slinton /* O_DUMP */ 0, null, "dump", 1609674Slinton /* O_EDIT */ 0, null, "edit", 1619674Slinton /* O_FUNC */ 1, null, "func", 1629674Slinton /* O_GRIPE */ 0, null, "gripe", 1639674Slinton /* O_HELP */ 0, null, "help", 1649674Slinton /* O_IGNORE */ 0, null, "ignore", 1659674Slinton /* O_LIST */ 2, null, "list", 1669674Slinton /* O_PRINT */ 1, null, "print", 1679674Slinton /* O_PSYM */ 1, null, "psym", 1689674Slinton /* O_RUN */ 0, null, "run", 1699674Slinton /* O_SKIP */ 0, null, "skip", 1709674Slinton /* O_SOURCE */ 0, null, "source", 1719674Slinton /* O_STATUS */ 0, null, "status", 1729674Slinton /* O_STEP */ 0, null, "step", 1739674Slinton /* O_STOP */ 3, null, "stop", 1749674Slinton /* O_STOPI */ 3, null, "stopi", 1759674Slinton /* O_TRACE */ 3, null, "trace", 1769674Slinton /* O_TRACEI */ 3, null, "tracei", 1779674Slinton /* O_WHATIS */ 1, null, "whatis", 1789674Slinton /* O_WHERE */ 0, null, "where", 1799674Slinton /* O_WHEREIS */ 1, null, "whereis", 1809674Slinton /* O_WHICH */ 1, null, "which", 1819674Slinton /* O_EXAMINE */ 0, null, "examine", 1829674Slinton 1839674Slinton /* O_ADDEVENT */ 0, null, "when", 1849674Slinton /* O_ENDX */ 0, null, nil, 1859674Slinton /* O_IF */ 0, null, "if", 1869674Slinton /* O_ONCE */ 0, null, "once", 1879674Slinton /* O_PRINTCALL */ 1, null, "printcall", 1889674Slinton /* O_PRINTIFCHANGED */ 1, null, "printifchanged", 1899674Slinton /* O_PRINTRTN */ 1, null, "printrtn", 1909674Slinton /* O_PRINTSRCPOS */ 1, null, "printsrcpos", 1919674Slinton /* O_PROCRTN */ 1, null, "procrtn", 1929674Slinton /* O_QLINE */ 2, null, nil, 1939674Slinton /* O_STOPIFCHANGED */ 1, null, "stopifchanged", 1949674Slinton /* O_STOPX */ 0, null, "stop", 1959674Slinton /* O_TRACEON */ 1, null, "traceon", 1969674Slinton /* O_TRACEOFF */ 1, null, "traceoff", 197*11166Slinton /* O_TYPERENAME */ 2, UNARY, "traceoff", 1989674Slinton }; 199