2 3ebbd193 2017-06-19 rsc #define PI 3.1415926535897932384626433832795028841971693993751
5 3ebbd193 2017-06-19 rsc #define MAXWID 8.5 /* default limits max picture to 8.5 x 11; */
6 3ebbd193 2017-06-19 rsc #define MAXHT 11 /* change to taste without peril */
8 3ebbd193 2017-06-19 rsc #define dprintf if(dbg)printf
10 3ebbd193 2017-06-19 rsc extern void yyerror(char *);
12 fafa622a 2020-01-12 rsc extern char errbuf[1000];
14 3ebbd193 2017-06-19 rsc #undef sprintf /* Snow Leopard */
16 3ebbd193 2017-06-19 rsc #define ERROR sprintf(errbuf,
17 3ebbd193 2017-06-19 rsc #define FATAL ), yyerror(errbuf), exit(1)
18 3ebbd193 2017-06-19 rsc #define WARNING ), yyerror(errbuf)
20 3ebbd193 2017-06-19 rsc #define DEFAULT 0
22 3ebbd193 2017-06-19 rsc #define HEAD1 1
23 3ebbd193 2017-06-19 rsc #define HEAD2 2
24 3ebbd193 2017-06-19 rsc #define HEAD12 (HEAD1+HEAD2)
25 3ebbd193 2017-06-19 rsc #define INVIS 4
26 3ebbd193 2017-06-19 rsc #define CW_ARC 8 /* clockwise arc */
27 3ebbd193 2017-06-19 rsc #define DOTBIT 16 /* line styles */
28 3ebbd193 2017-06-19 rsc #define DASHBIT 32
29 3ebbd193 2017-06-19 rsc #define FILLBIT 64 /* gray-fill on boxes, etc. */
30 3ebbd193 2017-06-19 rsc #define NOEDGEBIT 128 /* no edge on filled object */
32 3ebbd193 2017-06-19 rsc #define CENTER 01 /* text attributes */
33 3ebbd193 2017-06-19 rsc #define LJUST 02
34 3ebbd193 2017-06-19 rsc #define RJUST 04
35 3ebbd193 2017-06-19 rsc #define ABOVE 010
36 3ebbd193 2017-06-19 rsc #define BELOW 020
37 3ebbd193 2017-06-19 rsc #define SPREAD 040
39 3ebbd193 2017-06-19 rsc #define SCALE 1.0 /* default scale: units/inch */
40 3ebbd193 2017-06-19 rsc #define WID 0.75 /* default width for boxes and ellipses */
41 3ebbd193 2017-06-19 rsc #define WID2 0.375
42 3ebbd193 2017-06-19 rsc #define HT 0.5 /* default height and line length */
43 3ebbd193 2017-06-19 rsc #define HT2 (HT/2)
44 3ebbd193 2017-06-19 rsc #define HT5 (HT/5)
45 3ebbd193 2017-06-19 rsc #define HT10 (HT/10)
47 3ebbd193 2017-06-19 rsc /* these have to be like so, so that we can write */
48 3ebbd193 2017-06-19 rsc /* things like R & V, etc. */
51 3ebbd193 2017-06-19 rsc #define R_DIR 0
52 3ebbd193 2017-06-19 rsc #define U_DIR 1
53 3ebbd193 2017-06-19 rsc #define L_DIR 2
54 3ebbd193 2017-06-19 rsc #define D_DIR 3
55 3ebbd193 2017-06-19 rsc #define ishor(n) (((n) & V) == 0)
56 3ebbd193 2017-06-19 rsc #define isvert(n) (((n) & V) != 0)
57 3ebbd193 2017-06-19 rsc #define isright(n) ((n) == R_DIR)
58 3ebbd193 2017-06-19 rsc #define isleft(n) ((n) == L_DIR)
59 3ebbd193 2017-06-19 rsc #define isdown(n) ((n) == D_DIR)
60 3ebbd193 2017-06-19 rsc #define isup(n) ((n) == U_DIR)
62 3ebbd193 2017-06-19 rsc typedef float ofloat; /* for o_val[] in obj; could be double */
64 3ebbd193 2017-06-19 rsc typedef struct obj { /* stores various things in variable length */
66 3ebbd193 2017-06-19 rsc int o_count; /* number of things */
67 3ebbd193 2017-06-19 rsc int o_nobj; /* index in objlist */
68 3ebbd193 2017-06-19 rsc int o_mode; /* hor or vert */
69 3ebbd193 2017-06-19 rsc float o_x; /* coord of "center" */
71 3ebbd193 2017-06-19 rsc int o_nt1; /* 1st index in text[] for this object */
72 3ebbd193 2017-06-19 rsc int o_nt2; /* 2nd; difference is #text strings */
73 3ebbd193 2017-06-19 rsc int o_attr; /* HEAD, CW, INVIS, etc., go here */
74 3ebbd193 2017-06-19 rsc int o_size; /* linesize */
75 3ebbd193 2017-06-19 rsc int o_nhead; /* arrowhead style */
76 3ebbd193 2017-06-19 rsc struct symtab *o_symtab; /* symtab for [...] */
77 3ebbd193 2017-06-19 rsc float o_ddval; /* value of dot/dash expression */
78 3ebbd193 2017-06-19 rsc float o_fillval; /* gray scale value */
79 3ebbd193 2017-06-19 rsc ofloat o_val[1]; /* actually this will be > 1 in general */
80 3ebbd193 2017-06-19 rsc /* type is not always FLOAT!!!! */
83 3ebbd193 2017-06-19 rsc typedef union { /* the yacc stack type */
88 3ebbd193 2017-06-19 rsc struct symtab *st;
91 3ebbd193 2017-06-19 rsc extern YYSTYPE yylval, yyval;
93 3ebbd193 2017-06-19 rsc struct symtab {
94 3ebbd193 2017-06-19 rsc char *s_name;
96 3ebbd193 2017-06-19 rsc YYSTYPE s_val;
97 3ebbd193 2017-06-19 rsc struct symtab *s_next;
100 3ebbd193 2017-06-19 rsc typedef struct { /* attribute of an object */
103 3ebbd193 2017-06-19 rsc YYSTYPE a_val;
106 3ebbd193 2017-06-19 rsc typedef struct {
107 3ebbd193 2017-06-19 rsc int t_type; /* CENTER, LJUST, etc. */
108 3ebbd193 2017-06-19 rsc char t_op; /* optional sign for size changes */
109 3ebbd193 2017-06-19 rsc char t_size; /* size, abs or rel */
110 3ebbd193 2017-06-19 rsc char *t_val;
113 3ebbd193 2017-06-19 rsc #define String 01
114 3ebbd193 2017-06-19 rsc #define Macro 02
115 3ebbd193 2017-06-19 rsc #define File 04
116 3ebbd193 2017-06-19 rsc #define Char 010
117 3ebbd193 2017-06-19 rsc #define Thru 020
118 3ebbd193 2017-06-19 rsc #define Free 040
120 3ebbd193 2017-06-19 rsc typedef struct { /* input source */
121 3ebbd193 2017-06-19 rsc int type; /* Macro, String, File */
122 3ebbd193 2017-06-19 rsc char *sp; /* if String or Macro */
125 3ebbd193 2017-06-19 rsc extern Src src[], *srcp; /* input source stack */
127 3ebbd193 2017-06-19 rsc typedef struct {
129 3ebbd193 2017-06-19 rsc char *fname;
133 3ebbd193 2017-06-19 rsc extern Infile infile[], *curfile;
135 3ebbd193 2017-06-19 rsc #define MAXARGS 20
136 3ebbd193 2017-06-19 rsc typedef struct { /* argument stack */
137 3ebbd193 2017-06-19 rsc char *argstk[MAXARGS]; /* pointers to args */
138 3ebbd193 2017-06-19 rsc char *argval; /* points to space containing args */
141 3ebbd193 2017-06-19 rsc extern int dbg;
142 3ebbd193 2017-06-19 rsc extern obj **objlist;
143 3ebbd193 2017-06-19 rsc extern int nobj, nobjlist;
144 3ebbd193 2017-06-19 rsc extern Attr *attr;
145 3ebbd193 2017-06-19 rsc extern int nattr, nattrlist;
146 3ebbd193 2017-06-19 rsc extern Text *text;
147 3ebbd193 2017-06-19 rsc extern int ntextlist;
148 3ebbd193 2017-06-19 rsc extern int ntext;
149 3ebbd193 2017-06-19 rsc extern int ntext1;
150 3ebbd193 2017-06-19 rsc extern double curx, cury;
151 3ebbd193 2017-06-19 rsc extern int hvmode;
152 3ebbd193 2017-06-19 rsc extern int codegen;
153 3ebbd193 2017-06-19 rsc extern char *PEstring;
155 3ebbd193 2017-06-19 rsc char *tostring(char *);
156 3ebbd193 2017-06-19 rsc char *grow(char *, char *, int, int);
157 3ebbd193 2017-06-19 rsc double getfval(char *), getcomp(obj *, int), getblkvar(obj *, char *);
158 3ebbd193 2017-06-19 rsc YYSTYPE getvar(char *);
159 3ebbd193 2017-06-19 rsc struct symtab *lookup(char *), *makevar(char *, int, YYSTYPE);
160 3ebbd193 2017-06-19 rsc char *ifstat(double, char *, char *), *delimstr(char *), *sprintgen(char *);
161 3ebbd193 2017-06-19 rsc void forloop(char *var, double from, double to, int op, double by, char *_str);
162 3ebbd193 2017-06-19 rsc int setdir(int), curdir(void);
163 3ebbd193 2017-06-19 rsc void resetvar(void);
164 3ebbd193 2017-06-19 rsc void checkscale(char *);
165 3ebbd193 2017-06-19 rsc void pushsrc(int, char *);
166 3ebbd193 2017-06-19 rsc void copy(void);
167 3ebbd193 2017-06-19 rsc void copyuntil(char *);
168 3ebbd193 2017-06-19 rsc void copyfile(char *);
169 3ebbd193 2017-06-19 rsc void copydef(struct symtab *);
170 3ebbd193 2017-06-19 rsc void definition(char *);
171 3ebbd193 2017-06-19 rsc struct symtab *copythru(char *);
172 3ebbd193 2017-06-19 rsc int input(void);
173 3ebbd193 2017-06-19 rsc int unput(int);
174 3ebbd193 2017-06-19 rsc void extreme(double, double);
176 3ebbd193 2017-06-19 rsc extern double deltx, delty;
177 3ebbd193 2017-06-19 rsc extern int lineno;
178 3ebbd193 2017-06-19 rsc extern int synerr;
180 3ebbd193 2017-06-19 rsc extern double xmin, ymin, xmax, ymax;
182 3ebbd193 2017-06-19 rsc obj *leftthing(int), *boxgen(void), *circgen(int), *arcgen(int);
183 3ebbd193 2017-06-19 rsc obj *linegen(int), *splinegen(void), *movegen(void);
184 3ebbd193 2017-06-19 rsc obj *textgen(void), *plotgen(void);
185 3ebbd193 2017-06-19 rsc obj *troffgen(char *), *rightthing(obj *, int), *blockgen(obj *, obj *);
186 3ebbd193 2017-06-19 rsc obj *makenode(int, int), *makepos(double, double);
187 3ebbd193 2017-06-19 rsc obj *fixpos(obj *, double, double);
188 3ebbd193 2017-06-19 rsc obj *addpos(obj *, obj *), *subpos(obj *, obj *);
189 3ebbd193 2017-06-19 rsc obj *makebetween(double, obj *, obj *);
190 3ebbd193 2017-06-19 rsc obj *getpos(obj *, int), *gethere(void), *getfirst(int, int);
191 3ebbd193 2017-06-19 rsc obj *getlast(int, int), *getblock(obj *, char *);
192 3ebbd193 2017-06-19 rsc void savetext(int, char *);
193 3ebbd193 2017-06-19 rsc void makeiattr(int, int);
194 3ebbd193 2017-06-19 rsc void makevattr(char *);
195 3ebbd193 2017-06-19 rsc void makefattr(int type, int sub, double f);
196 3ebbd193 2017-06-19 rsc void maketattr(int, char *);
197 3ebbd193 2017-06-19 rsc void makeoattr(int, obj *);
198 3ebbd193 2017-06-19 rsc void makeattr(int type, int sub, YYSTYPE val);
199 3ebbd193 2017-06-19 rsc void printexpr(double);
200 3ebbd193 2017-06-19 rsc void printpos(obj *);
201 3ebbd193 2017-06-19 rsc void exprsave(double);
202 3ebbd193 2017-06-19 rsc void addtattr(int);
203 3ebbd193 2017-06-19 rsc void printlf(int, char *);
205 3ebbd193 2017-06-19 rsc struct pushstack {
208 3ebbd193 2017-06-19 rsc int p_hvmode;
209 3ebbd193 2017-06-19 rsc double p_xmin;
210 3ebbd193 2017-06-19 rsc double p_ymin;
211 3ebbd193 2017-06-19 rsc double p_xmax;
212 3ebbd193 2017-06-19 rsc double p_ymax;
213 3ebbd193 2017-06-19 rsc struct symtab *p_symtab;
215 3ebbd193 2017-06-19 rsc extern struct pushstack stack[];
216 3ebbd193 2017-06-19 rsc extern int nstack;
217 3ebbd193 2017-06-19 rsc extern int cw;
219 3ebbd193 2017-06-19 rsc extern double errcheck(double, char *);
220 3ebbd193 2017-06-19 rsc #define Log10(x) errcheck(log10(x), "log")
221 3ebbd193 2017-06-19 rsc #define Exp(x) errcheck(exp(x), "exp")
222 3ebbd193 2017-06-19 rsc #define Sqrt(x) errcheck(sqrt(x), "sqrt")