13e12c5d1SDavid du Colombier #ifndef PI 23e12c5d1SDavid du Colombier #define PI 3.1415926535897932384626433832795028841971693993751 33e12c5d1SDavid du Colombier #endif 43e12c5d1SDavid du Colombier 53e12c5d1SDavid du Colombier #define MAXWID 8.5 /* default limits max picture to 8.5 x 11; */ 63e12c5d1SDavid du Colombier #define MAXHT 11 /* change to taste without peril */ 73e12c5d1SDavid du Colombier 83e12c5d1SDavid du Colombier #define dprintf if(dbg)printf 93e12c5d1SDavid du Colombier 103e12c5d1SDavid du Colombier extern void yyerror(char *); 113e12c5d1SDavid du Colombier 123e12c5d1SDavid du Colombier extern char errbuf[200]; 133e12c5d1SDavid du Colombier #define ERROR sprintf(errbuf, 14*7dd7cddfSDavid du Colombier #define FATAL ), yyerror(errbuf), exit(1) 153e12c5d1SDavid du Colombier #define WARNING ), yyerror(errbuf) 163e12c5d1SDavid du Colombier 173e12c5d1SDavid du Colombier #define DEFAULT 0 183e12c5d1SDavid du Colombier 193e12c5d1SDavid du Colombier #define HEAD1 1 203e12c5d1SDavid du Colombier #define HEAD2 2 213e12c5d1SDavid du Colombier #define HEAD12 (HEAD1+HEAD2) 223e12c5d1SDavid du Colombier #define INVIS 4 233e12c5d1SDavid du Colombier #define CW_ARC 8 /* clockwise arc */ 243e12c5d1SDavid du Colombier #define DOTBIT 16 /* line styles */ 253e12c5d1SDavid du Colombier #define DASHBIT 32 263e12c5d1SDavid du Colombier #define FILLBIT 64 /* gray-fill on boxes, etc. */ 27*7dd7cddfSDavid du Colombier #define NOEDGEBIT 128 /* no edge on filled object */ 283e12c5d1SDavid du Colombier 293e12c5d1SDavid du Colombier #define CENTER 01 /* text attributes */ 303e12c5d1SDavid du Colombier #define LJUST 02 313e12c5d1SDavid du Colombier #define RJUST 04 323e12c5d1SDavid du Colombier #define ABOVE 010 333e12c5d1SDavid du Colombier #define BELOW 020 343e12c5d1SDavid du Colombier #define SPREAD 040 353e12c5d1SDavid du Colombier 363e12c5d1SDavid du Colombier #define SCALE 1.0 /* default scale: units/inch */ 373e12c5d1SDavid du Colombier #define WID 0.75 /* default width for boxes and ellipses */ 383e12c5d1SDavid du Colombier #define WID2 0.375 393e12c5d1SDavid du Colombier #define HT 0.5 /* default height and line length */ 403e12c5d1SDavid du Colombier #define HT2 (HT/2) 413e12c5d1SDavid du Colombier #define HT5 (HT/5) 423e12c5d1SDavid du Colombier #define HT10 (HT/10) 433e12c5d1SDavid du Colombier 443e12c5d1SDavid du Colombier /* these have to be like so, so that we can write */ 453e12c5d1SDavid du Colombier /* things like R & V, etc. */ 463e12c5d1SDavid du Colombier #define H 0 473e12c5d1SDavid du Colombier #define V 1 483e12c5d1SDavid du Colombier #define R_DIR 0 493e12c5d1SDavid du Colombier #define U_DIR 1 503e12c5d1SDavid du Colombier #define L_DIR 2 513e12c5d1SDavid du Colombier #define D_DIR 3 523e12c5d1SDavid du Colombier #define ishor(n) (((n) & V) == 0) 533e12c5d1SDavid du Colombier #define isvert(n) (((n) & V) != 0) 543e12c5d1SDavid du Colombier #define isright(n) ((n) == R_DIR) 553e12c5d1SDavid du Colombier #define isleft(n) ((n) == L_DIR) 563e12c5d1SDavid du Colombier #define isdown(n) ((n) == D_DIR) 573e12c5d1SDavid du Colombier #define isup(n) ((n) == U_DIR) 583e12c5d1SDavid du Colombier 593e12c5d1SDavid du Colombier typedef float ofloat; /* for o_val[] in obj; could be double */ 603e12c5d1SDavid du Colombier 613e12c5d1SDavid du Colombier typedef struct obj { /* stores various things in variable length */ 623e12c5d1SDavid du Colombier int o_type; 633e12c5d1SDavid du Colombier int o_count; /* number of things */ 643e12c5d1SDavid du Colombier int o_nobj; /* index in objlist */ 653e12c5d1SDavid du Colombier int o_mode; /* hor or vert */ 663e12c5d1SDavid du Colombier float o_x; /* coord of "center" */ 673e12c5d1SDavid du Colombier float o_y; 683e12c5d1SDavid du Colombier int o_nt1; /* 1st index in text[] for this object */ 693e12c5d1SDavid du Colombier int o_nt2; /* 2nd; difference is #text strings */ 703e12c5d1SDavid du Colombier int o_attr; /* HEAD, CW, INVIS, etc., go here */ 713e12c5d1SDavid du Colombier int o_size; /* linesize */ 723e12c5d1SDavid du Colombier int o_nhead; /* arrowhead style */ 733e12c5d1SDavid du Colombier struct symtab *o_symtab; /* symtab for [...] */ 743e12c5d1SDavid du Colombier float o_ddval; /* value of dot/dash expression */ 753e12c5d1SDavid du Colombier float o_fillval; /* gray scale value */ 763e12c5d1SDavid du Colombier ofloat o_val[1]; /* actually this will be > 1 in general */ 773e12c5d1SDavid du Colombier /* type is not always FLOAT!!!! */ 783e12c5d1SDavid du Colombier } obj; 793e12c5d1SDavid du Colombier 803e12c5d1SDavid du Colombier typedef union { /* the yacc stack type */ 813e12c5d1SDavid du Colombier int i; 823e12c5d1SDavid du Colombier char *p; 833e12c5d1SDavid du Colombier obj *o; 843e12c5d1SDavid du Colombier double f; 853e12c5d1SDavid du Colombier struct symtab *st; 863e12c5d1SDavid du Colombier } YYSTYPE; 873e12c5d1SDavid du Colombier 883e12c5d1SDavid du Colombier extern YYSTYPE yylval, yyval; 893e12c5d1SDavid du Colombier 903e12c5d1SDavid du Colombier struct symtab { 913e12c5d1SDavid du Colombier char *s_name; 923e12c5d1SDavid du Colombier int s_type; 933e12c5d1SDavid du Colombier YYSTYPE s_val; 943e12c5d1SDavid du Colombier struct symtab *s_next; 953e12c5d1SDavid du Colombier }; 963e12c5d1SDavid du Colombier 973e12c5d1SDavid du Colombier typedef struct { /* attribute of an object */ 983e12c5d1SDavid du Colombier int a_type; 993e12c5d1SDavid du Colombier int a_sub; 1003e12c5d1SDavid du Colombier YYSTYPE a_val; 1013e12c5d1SDavid du Colombier } Attr; 1023e12c5d1SDavid du Colombier 1033e12c5d1SDavid du Colombier typedef struct { 1043e12c5d1SDavid du Colombier int t_type; /* CENTER, LJUST, etc. */ 1053e12c5d1SDavid du Colombier char t_op; /* optional sign for size changes */ 1063e12c5d1SDavid du Colombier char t_size; /* size, abs or rel */ 1073e12c5d1SDavid du Colombier char *t_val; 1083e12c5d1SDavid du Colombier } Text; 1093e12c5d1SDavid du Colombier 1103e12c5d1SDavid du Colombier #define String 01 1113e12c5d1SDavid du Colombier #define Macro 02 1123e12c5d1SDavid du Colombier #define File 04 1133e12c5d1SDavid du Colombier #define Char 010 1143e12c5d1SDavid du Colombier #define Thru 020 1153e12c5d1SDavid du Colombier #define Free 040 1163e12c5d1SDavid du Colombier 1173e12c5d1SDavid du Colombier typedef struct { /* input source */ 1183e12c5d1SDavid du Colombier int type; /* Macro, String, File */ 1193e12c5d1SDavid du Colombier char *sp; /* if String or Macro */ 1203e12c5d1SDavid du Colombier } Src; 1213e12c5d1SDavid du Colombier 1223e12c5d1SDavid du Colombier extern Src src[], *srcp; /* input source stack */ 1233e12c5d1SDavid du Colombier 1243e12c5d1SDavid du Colombier typedef struct { 1253e12c5d1SDavid du Colombier FILE *fin; 1263e12c5d1SDavid du Colombier char *fname; 1273e12c5d1SDavid du Colombier int lineno; 1283e12c5d1SDavid du Colombier } Infile; 1293e12c5d1SDavid du Colombier 1303e12c5d1SDavid du Colombier extern Infile infile[], *curfile; 1313e12c5d1SDavid du Colombier 1323e12c5d1SDavid du Colombier #define MAXARGS 20 1333e12c5d1SDavid du Colombier typedef struct { /* argument stack */ 1343e12c5d1SDavid du Colombier char *argstk[MAXARGS]; /* pointers to args */ 1353e12c5d1SDavid du Colombier char *argval; /* points to space containing args */ 1363e12c5d1SDavid du Colombier } Arg; 1373e12c5d1SDavid du Colombier 1383e12c5d1SDavid du Colombier extern int dbg; 1393e12c5d1SDavid du Colombier extern obj **objlist; 1403e12c5d1SDavid du Colombier extern int nobj, nobjlist; 1413e12c5d1SDavid du Colombier extern Attr *attr; 1423e12c5d1SDavid du Colombier extern int nattr, nattrlist; 1433e12c5d1SDavid du Colombier extern Text *text; 1443e12c5d1SDavid du Colombier extern int ntextlist; 1453e12c5d1SDavid du Colombier extern int ntext; 1463e12c5d1SDavid du Colombier extern int ntext1; 1473e12c5d1SDavid du Colombier extern double curx, cury; 1483e12c5d1SDavid du Colombier extern int hvmode; 1493e12c5d1SDavid du Colombier extern int codegen; 150*7dd7cddfSDavid du Colombier extern char *PEstring; 1513e12c5d1SDavid du Colombier 1523e12c5d1SDavid du Colombier char *tostring(char *); 1533e12c5d1SDavid du Colombier char *grow(char *, char *, int, int); 1543e12c5d1SDavid du Colombier double getfval(char *), getcomp(obj *, int), getblkvar(obj *, char *); 1553e12c5d1SDavid du Colombier YYSTYPE getvar(char *); 1563e12c5d1SDavid du Colombier struct symtab *lookup(char *), *makevar(char *, int, YYSTYPE); 1573e12c5d1SDavid du Colombier char *ifstat(double, char *, char *), *delimstr(char *), *sprintgen(char *); 1583e12c5d1SDavid du Colombier void forloop(char *var, double from, double to, int op, double by, char *_str); 1593e12c5d1SDavid du Colombier int setdir(int), curdir(void); 1603e12c5d1SDavid du Colombier void resetvar(void); 1613e12c5d1SDavid du Colombier void checkscale(char *); 1623e12c5d1SDavid du Colombier void pushsrc(int, char *); 1633e12c5d1SDavid du Colombier void copy(void); 1643e12c5d1SDavid du Colombier void copyuntil(char *); 1653e12c5d1SDavid du Colombier void copyfile(char *); 1663e12c5d1SDavid du Colombier void copydef(struct symtab *); 1673e12c5d1SDavid du Colombier void definition(char *); 1683e12c5d1SDavid du Colombier struct symtab *copythru(char *); 1693e12c5d1SDavid du Colombier int input(void); 1703e12c5d1SDavid du Colombier int unput(int); 1713e12c5d1SDavid du Colombier void extreme(double, double); 1723e12c5d1SDavid du Colombier 1733e12c5d1SDavid du Colombier extern double deltx, delty; 1743e12c5d1SDavid du Colombier extern int lineno; 1753e12c5d1SDavid du Colombier extern int synerr; 1763e12c5d1SDavid du Colombier 1773e12c5d1SDavid du Colombier extern double xmin, ymin, xmax, ymax; 1783e12c5d1SDavid du Colombier 1793e12c5d1SDavid du Colombier obj *leftthing(int), *boxgen(void), *circgen(int), *arcgen(int); 1803e12c5d1SDavid du Colombier obj *linegen(int), *splinegen(void), *movegen(void); 1813e12c5d1SDavid du Colombier obj *textgen(void), *plotgen(void); 1823e12c5d1SDavid du Colombier obj *troffgen(char *), *rightthing(obj *, int), *blockgen(obj *, obj *); 1833e12c5d1SDavid du Colombier obj *makenode(int, int), *makepos(double, double); 1843e12c5d1SDavid du Colombier obj *fixpos(obj *, double, double); 1853e12c5d1SDavid du Colombier obj *addpos(obj *, obj *), *subpos(obj *, obj *); 1863e12c5d1SDavid du Colombier obj *makebetween(double, obj *, obj *); 1873e12c5d1SDavid du Colombier obj *getpos(obj *, int), *gethere(void), *getfirst(int, int); 1883e12c5d1SDavid du Colombier obj *getlast(int, int), *getblock(obj *, char *); 1893e12c5d1SDavid du Colombier void savetext(int, char *); 1903e12c5d1SDavid du Colombier void makeiattr(int, int); 1913e12c5d1SDavid du Colombier void makevattr(char *); 1923e12c5d1SDavid du Colombier void makefattr(int type, int sub, double f); 1933e12c5d1SDavid du Colombier void maketattr(int, char *); 1943e12c5d1SDavid du Colombier void makeoattr(int, obj *); 195*7dd7cddfSDavid du Colombier void makeattr(int type, int sub, YYSTYPE val); 1963e12c5d1SDavid du Colombier void printexpr(double); 1973e12c5d1SDavid du Colombier void printpos(obj *); 1983e12c5d1SDavid du Colombier void exprsave(double); 1993e12c5d1SDavid du Colombier void addtattr(int); 2003e12c5d1SDavid du Colombier void printlf(int, char *); 2013e12c5d1SDavid du Colombier 2023e12c5d1SDavid du Colombier struct pushstack { 2033e12c5d1SDavid du Colombier double p_x; 2043e12c5d1SDavid du Colombier double p_y; 2053e12c5d1SDavid du Colombier int p_hvmode; 2063e12c5d1SDavid du Colombier double p_xmin; 2073e12c5d1SDavid du Colombier double p_ymin; 2083e12c5d1SDavid du Colombier double p_xmax; 2093e12c5d1SDavid du Colombier double p_ymax; 2103e12c5d1SDavid du Colombier struct symtab *p_symtab; 2113e12c5d1SDavid du Colombier }; 2123e12c5d1SDavid du Colombier extern struct pushstack stack[]; 2133e12c5d1SDavid du Colombier extern int nstack; 2143e12c5d1SDavid du Colombier extern int cw; 2153e12c5d1SDavid du Colombier 2163e12c5d1SDavid du Colombier extern double errcheck(double, char *); 2173e12c5d1SDavid du Colombier #define Log10(x) errcheck(log10(x), "log") 2183e12c5d1SDavid du Colombier #define Exp(x) errcheck(exp(x), "exp") 2193e12c5d1SDavid du Colombier #define Sqrt(x) errcheck(sqrt(x), "sqrt") 220