Blame


1 5cedca1b 2004-05-15 devnull #include <stdio.h>
2 5cedca1b 2004-05-15 devnull #include <signal.h>
3 5cedca1b 2004-05-15 devnull #include <math.h>
4 5cedca1b 2004-05-15 devnull #include <stdlib.h>
5 b237df90 2004-05-16 devnull #include <unistd.h>
6 5cedca1b 2004-05-15 devnull #include <string.h>
7 5cedca1b 2004-05-15 devnull #include "grap.h"
8 5cedca1b 2004-05-15 devnull #include "y.tab.h"
9 5cedca1b 2004-05-15 devnull
10 5cedca1b 2004-05-15 devnull int dbg = 0;
11 5cedca1b 2004-05-15 devnull
12 1e1cea29 2004-05-17 devnull #ifndef GRAPDEFINES
13 d16cfe24 2004-08-16 devnull #define GRAPDEFINES "#9/lib/grap.defines"
14 1e1cea29 2004-05-17 devnull #endif
15 b237df90 2004-05-16 devnull char *lib_defines;
16 5cedca1b 2004-05-15 devnull
17 5cedca1b 2004-05-15 devnull int lib = 1; /* 1 to include lib_defines */
18 5cedca1b 2004-05-15 devnull FILE *tfd = NULL;
19 b237df90 2004-05-16 devnull char *tempfile;
20 5cedca1b 2004-05-15 devnull
21 5cedca1b 2004-05-15 devnull int synerr = 0;
22 5cedca1b 2004-05-15 devnull int codegen = 0; /* 1=>output for this picture; 0=>no output */
23 5cedca1b 2004-05-15 devnull char *cmdname;
24 5cedca1b 2004-05-15 devnull
25 5cedca1b 2004-05-15 devnull Obj *objlist = NULL; /* all names stored here */
26 5cedca1b 2004-05-15 devnull
27 5cedca1b 2004-05-15 devnull #define BIG 1e30
28 5cedca1b 2004-05-15 devnull Point ptmin = { NULL, -BIG, -BIG };
29 5cedca1b 2004-05-15 devnull Point ptmax = { NULL, BIG, BIG };
30 5cedca1b 2004-05-15 devnull
31 5cedca1b 2004-05-15 devnull char *version = "version Dec 30, 1995";
32 5cedca1b 2004-05-15 devnull
33 5cedca1b 2004-05-15 devnull extern int yyparse(void);
34 5cedca1b 2004-05-15 devnull extern void setdefaults(void);
35 5cedca1b 2004-05-15 devnull extern void getdata(void);
36 5cedca1b 2004-05-15 devnull
37 b237df90 2004-05-16 devnull /* extern int unlink(char *); */ /* in unistd.h */
38 b237df90 2004-05-16 devnull
39 b237df90 2004-05-16 devnull int
40 5cedca1b 2004-05-15 devnull main(int argc, char *argv[])
41 5cedca1b 2004-05-15 devnull {
42 5cedca1b 2004-05-15 devnull extern void onintr(int), fpecatch(int);
43 5cedca1b 2004-05-15 devnull
44 1e1cea29 2004-05-17 devnull lib_defines = unsharp(GRAPDEFINES);
45 b237df90 2004-05-16 devnull
46 5cedca1b 2004-05-15 devnull if (signal(SIGINT, SIG_IGN) != SIG_IGN)
47 5cedca1b 2004-05-15 devnull signal(SIGINT, onintr);
48 5cedca1b 2004-05-15 devnull signal(SIGFPE, fpecatch);
49 5cedca1b 2004-05-15 devnull cmdname = argv[0];
50 b237df90 2004-05-16 devnull tempfile = strdup("grap.XXXXXX");
51 b237df90 2004-05-16 devnull mkstemp(tempfile);
52 5cedca1b 2004-05-15 devnull while (argc > 1 && *argv[1] == '-') {
53 5cedca1b 2004-05-15 devnull switch (argv[1][1]) {
54 5cedca1b 2004-05-15 devnull case 'd':
55 5cedca1b 2004-05-15 devnull dbg = 1;
56 5cedca1b 2004-05-15 devnull tfd = stdout;
57 5cedca1b 2004-05-15 devnull strcpy(tempfile, "grap.temp");
58 5cedca1b 2004-05-15 devnull unlink(tempfile);
59 5cedca1b 2004-05-15 devnull fprintf(stderr, "%s\n", version);
60 5cedca1b 2004-05-15 devnull break;
61 5cedca1b 2004-05-15 devnull case 'l': /* turn off /usr/lib inclusion */
62 5cedca1b 2004-05-15 devnull lib = 0;
63 5cedca1b 2004-05-15 devnull break;
64 5cedca1b 2004-05-15 devnull }
65 5cedca1b 2004-05-15 devnull argc--;
66 5cedca1b 2004-05-15 devnull argv++;
67 5cedca1b 2004-05-15 devnull }
68 5cedca1b 2004-05-15 devnull setdefaults();
69 5cedca1b 2004-05-15 devnull curfile = infile;
70 5cedca1b 2004-05-15 devnull if (argc <= 1) {
71 5cedca1b 2004-05-15 devnull curfile->fin = stdin;
72 5cedca1b 2004-05-15 devnull curfile->fname = tostring("-");
73 5cedca1b 2004-05-15 devnull pushsrc(File, curfile->fname);
74 5cedca1b 2004-05-15 devnull getdata();
75 5cedca1b 2004-05-15 devnull } else
76 5cedca1b 2004-05-15 devnull while (argc-- > 1) {
77 5cedca1b 2004-05-15 devnull if ((curfile->fin = fopen(*++argv, "r")) == NULL) {
78 5cedca1b 2004-05-15 devnull fprintf(stderr, "grap: can't open %s\n", *argv);
79 5cedca1b 2004-05-15 devnull onintr(0);
80 5cedca1b 2004-05-15 devnull }
81 5cedca1b 2004-05-15 devnull curfile->fname = tostring(*argv);
82 5cedca1b 2004-05-15 devnull pushsrc(File, curfile->fname);
83 5cedca1b 2004-05-15 devnull getdata();
84 5cedca1b 2004-05-15 devnull fclose(curfile->fin);
85 5cedca1b 2004-05-15 devnull free(curfile->fname);
86 5cedca1b 2004-05-15 devnull }
87 5cedca1b 2004-05-15 devnull if (!dbg)
88 5cedca1b 2004-05-15 devnull unlink(tempfile);
89 5cedca1b 2004-05-15 devnull exit(0);
90 5cedca1b 2004-05-15 devnull }
91 5cedca1b 2004-05-15 devnull
92 5cedca1b 2004-05-15 devnull void onintr(int n)
93 5cedca1b 2004-05-15 devnull {
94 1e1cea29 2004-05-17 devnull if(n){}
95 1e1cea29 2004-05-17 devnull if(!dbg)
96 5cedca1b 2004-05-15 devnull unlink(tempfile);
97 5cedca1b 2004-05-15 devnull exit(1);
98 5cedca1b 2004-05-15 devnull }
99 5cedca1b 2004-05-15 devnull
100 5cedca1b 2004-05-15 devnull void fpecatch(int n)
101 5cedca1b 2004-05-15 devnull {
102 5cedca1b 2004-05-15 devnull ERROR "floating point exception" WARNING;
103 5cedca1b 2004-05-15 devnull onintr(n);
104 5cedca1b 2004-05-15 devnull }
105 5cedca1b 2004-05-15 devnull
106 5cedca1b 2004-05-15 devnull char *grow(char *ptr, char *name, int num, int size) /* make array bigger */
107 5cedca1b 2004-05-15 devnull {
108 5cedca1b 2004-05-15 devnull char *p;
109 5cedca1b 2004-05-15 devnull
110 5cedca1b 2004-05-15 devnull if (ptr == NULL)
111 5cedca1b 2004-05-15 devnull p = malloc(num * size);
112 5cedca1b 2004-05-15 devnull else
113 5cedca1b 2004-05-15 devnull p = realloc(ptr, num * size);
114 5cedca1b 2004-05-15 devnull if (p == NULL)
115 5cedca1b 2004-05-15 devnull ERROR "can't grow %s to %d", name, num * size FATAL;
116 5cedca1b 2004-05-15 devnull return p;
117 5cedca1b 2004-05-15 devnull }
118 5cedca1b 2004-05-15 devnull
119 5cedca1b 2004-05-15 devnull static struct {
120 5cedca1b 2004-05-15 devnull char *name;
121 5cedca1b 2004-05-15 devnull double val;
122 5cedca1b 2004-05-15 devnull } defaults[] ={
123 b237df90 2004-05-16 devnull { "frameht", FRAMEHT },
124 b237df90 2004-05-16 devnull { "framewid", FRAMEWID },
125 b237df90 2004-05-16 devnull { "ticklen", TICKLEN },
126 b237df90 2004-05-16 devnull { "slop", SLOP },
127 b237df90 2004-05-16 devnull { NULL, 0 }
128 5cedca1b 2004-05-15 devnull };
129 5cedca1b 2004-05-15 devnull
130 5cedca1b 2004-05-15 devnull void setdefaults(void) /* set default sizes for variables */
131 5cedca1b 2004-05-15 devnull {
132 5cedca1b 2004-05-15 devnull int i;
133 5cedca1b 2004-05-15 devnull Obj *p;
134 5cedca1b 2004-05-15 devnull
135 5cedca1b 2004-05-15 devnull for (i = 0; defaults[i].name != NULL; i++) {
136 5cedca1b 2004-05-15 devnull p = lookup(defaults[i].name, 1);
137 5cedca1b 2004-05-15 devnull setvar(p, defaults[i].val);
138 5cedca1b 2004-05-15 devnull }
139 5cedca1b 2004-05-15 devnull }
140 5cedca1b 2004-05-15 devnull
141 5cedca1b 2004-05-15 devnull void getdata(void) /* read input */
142 5cedca1b 2004-05-15 devnull {
143 5cedca1b 2004-05-15 devnull register FILE *fin;
144 5cedca1b 2004-05-15 devnull char buf[1000], buf1[100];
145 5cedca1b 2004-05-15 devnull int ln;
146 5cedca1b 2004-05-15 devnull
147 5cedca1b 2004-05-15 devnull fin = curfile->fin;
148 5cedca1b 2004-05-15 devnull curfile->lineno = 0;
149 5cedca1b 2004-05-15 devnull printf(".lf 1 %s\n", curfile->fname);
150 5cedca1b 2004-05-15 devnull while (fgets(buf, sizeof buf, fin) != NULL) {
151 5cedca1b 2004-05-15 devnull curfile->lineno++;
152 5cedca1b 2004-05-15 devnull if (*buf == '.' && *(buf+1) == 'G' && *(buf+2) == '1') {
153 5cedca1b 2004-05-15 devnull setup();
154 5cedca1b 2004-05-15 devnull fprintf(stdout, ".PS%s", &buf[3]); /* maps .G1 [w] to .PS w */
155 5cedca1b 2004-05-15 devnull printf("scale = 1\n"); /* defends against cip users */
156 5cedca1b 2004-05-15 devnull printf(".lf %d\n", curfile->lineno+1);
157 5cedca1b 2004-05-15 devnull yyparse();
158 5cedca1b 2004-05-15 devnull fprintf(stdout, ".PE\n");
159 5cedca1b 2004-05-15 devnull printf(".lf %d\n", curfile->lineno+1);
160 5cedca1b 2004-05-15 devnull fflush(stdout);
161 5cedca1b 2004-05-15 devnull } else if (buf[0] == '.' && buf[1] == 'l' && buf[2] == 'f') {
162 5cedca1b 2004-05-15 devnull if (sscanf(buf+3, "%d %s", &ln, buf1) == 2) {
163 5cedca1b 2004-05-15 devnull free(curfile->fname);
164 5cedca1b 2004-05-15 devnull printf(".lf %d %s\n", curfile->lineno = ln, curfile->fname = tostring(buf1));
165 5cedca1b 2004-05-15 devnull } else
166 5cedca1b 2004-05-15 devnull printf(".lf %d\n", curfile->lineno = ln);
167 5cedca1b 2004-05-15 devnull } else
168 5cedca1b 2004-05-15 devnull fputs(buf, stdout);
169 5cedca1b 2004-05-15 devnull }
170 5cedca1b 2004-05-15 devnull }