#define _BSD_SOURCE 1 /* strdup, mkstemp */ #define _DEFAULT_SOURCE 1 #include <stdio.h> #include <signal.h> #include <math.h> #include <stdlib.h> #include <unistd.h> #include <string.h> #include "grap.h" #include "y.tab.h" int dbg = 0; #ifndef GRAPDEFINES #define GRAPDEFINES "#9/lib/grap.defines" #endif char *lib_defines; int lib = 1; /* 1 to include lib_defines */ FILE *tfd = NULL; char *tempfile; int synerr = 0; int codegen = 0; /* 1=>output for this picture; 0=>no output */ char *cmdname; Obj *objlist = NULL; /* all names stored here */ #define BIG 1e30 Point ptmin = { NULL, -BIG, -BIG }; Point ptmax = { NULL, BIG, BIG }; char *version = "version Dec 30, 1995"; extern int yyparse(void); extern void setdefaults(void); extern void getdata(void); /* extern int unlink(char *); */ /* in unistd.h */ int main(int argc, char *argv[]) { extern void onintr(int), fpecatch(int); lib_defines = unsharp(GRAPDEFINES); if (signal(SIGINT, SIG_IGN) != SIG_IGN) signal(SIGINT, onintr); signal(SIGFPE, fpecatch); cmdname = argv[0]; tempfile = strdup("grap.XXXXXX"); mkstemp(tempfile); while (argc > 1 && *argv[1] == '-') { switch (argv[1][1]) { case 'd': dbg = 1; tfd = stdout; strcpy(tempfile, "grap.temp"); unlink(tempfile); fprintf(stderr, "%s\n", version); break; case 'l': /* turn off /usr/lib inclusion */ lib = 0; break; } argc--; argv++; } setdefaults(); curfile = infile; if (argc <= 1) { curfile->fin = stdin; curfile->fname = tostring("-"); pushsrc(File, curfile->fname); getdata(); } else while (argc-- > 1) { if ((curfile->fin = fopen(*++argv, "r")) == NULL) { fprintf(stderr, "grap: can't open %s\n", *argv); onintr(0); } curfile->fname = tostring(*argv); pushsrc(File, curfile->fname); getdata(); fclose(curfile->fin); free(curfile->fname); } if (!dbg) unlink(tempfile); exit(0); } void onintr(int n) { if(n){} if(!dbg) unlink(tempfile); exit(1); } void fpecatch(int n) { ERROR "floating point exception" WARNING; onintr(n); } char *grow(char *ptr, char *name, int num, int size) /* make array bigger */ { char *p; if (ptr == NULL) p = malloc(num * size); else p = realloc(ptr, num * size); if (p == NULL) ERROR "can't grow %s to %d", name, num * size FATAL; return p; } static struct { char *name; double val; } defaults[] ={ { "frameht", FRAMEHT }, { "framewid", FRAMEWID }, { "ticklen", TICKLEN }, { "slop", SLOP }, { NULL, 0 } }; void setdefaults(void) /* set default sizes for variables */ { int i; Obj *p; for (i = 0; defaults[i].name != NULL; i++) { p = lookup(defaults[i].name, 1); setvar(p, defaults[i].val); } } void getdata(void) /* read input */ { register FILE *fin; char buf[1000], buf1[100]; int ln; fin = curfile->fin; curfile->lineno = 0; printf(".lf 1 %s\n", curfile->fname); while (fgets(buf, sizeof buf, fin) != NULL) { curfile->lineno++; if (*buf == '.' && *(buf+1) == 'G' && *(buf+2) == '1') { setup(); fprintf(stdout, ".PS%s", &buf[3]); /* maps .G1 [w] to .PS w */ printf("scale = 1\n"); /* defends against cip users */ printf(".lf %d\n", curfile->lineno+1); yyparse(); fprintf(stdout, ".PE\n"); printf(".lf %d\n", curfile->lineno+1); fflush(stdout); } else if (buf[0] == '.' && buf[1] == 'l' && buf[2] == 'f') { if (sscanf(buf+3, "%d %s", &ln, buf1) == 2) { free(curfile->fname); printf(".lf %d %s\n", curfile->lineno = ln, curfile->fname = tostring(buf1)); } else printf(".lf %d\n", curfile->lineno = ln); } else fputs(buf, stdout); } }