10 double margin = MARGIN; /* extra space around edges */
11 extern double frame_ht, frame_wid, ticklen;
12 extern int just, sizeop, tick_dir;
13 extern double sizexpr, lab_up, lab_rt;
15 char graphname[50] = "Graph";
16 char graphpos[200] = "";
18 void print(void) /* arrange final output */
23 double dx, dy, xfac, yfac;
26 fclose(tfd); /* end the temp file */
30 if ((p=lookup("margin",0)) != NULL)
32 if (frame_ht < 0) /* wasn't set explicitly, so use default */
33 frame_ht = getvar(lookup("frameht", 0));
35 frame_wid = getvar(lookup("framewid", 0));
37 for (p = objlist; p; p = p->next) {
38 dprintf("print: name = <%s>, type = %d\n", p->name, p->type);
39 if (p->type == NAME) {
43 fprintf(tfd, "\t# %s %g .. %g, %g .. %g\n",
44 p->name, pt.x, pt1.x, pt.y, pt1.y);
47 ERROR "can't take log of x coord %g", pt.x FATAL;
53 ERROR "can't take log of y coord %g", pt.y FATAL;
57 if (!(p->coord & XFLAG)) {
62 if (!(p->coord & YFLAG)) {
67 if (autoticks && strcmp(p->name, dflt_coord) == 0) {
71 p->pt.x = pow(10.0, pt.x);
72 p->pt1.x = pow(10.0, pt1.x);
75 p->pt.y = pow(10.0, pt.y);
76 p->pt1.y = pow(10.0, pt1.y);
82 xfac = dx > 0 ? frame_wid/dx : frame_wid/2;
83 yfac = dy > 0 ? frame_ht/dy : frame_ht/2;
85 fprintf(tfd, "define xy_%s @ ", p->name);
87 fprintf(tfd, "\t(($1)-(%g))*%g", pt.x, xfac);
89 fprintf(tfd, "\t%g", xfac);
91 fprintf(tfd, ", (($2)-(%g))*%g @\n", pt.y, yfac);
93 fprintf(tfd, ", %g @\n", yfac);
94 fprintf(tfd, "define x_%s @ ", p->name);
96 fprintf(tfd, "\t(($1)-(%g))*%g @\n", pt.x, xfac);
98 fprintf(tfd, "\t%g @\n", xfac);
99 fprintf(tfd, "define y_%s @ ", p->name);
101 fprintf(tfd, "\t(($1)-(%g))*%g @\n", pt.y, yfac);
103 fprintf(tfd, "\t%g @\n", yfac);
108 if (codegen && autoticks && dfp)
111 if ((fd = fopen(tempfile, "r")) != NULL) {
112 while ((c = getc(fd)) != EOF)
119 void endstat(void) /* clean up after each statement */
123 lab_up = lab_rt = 0.0;
132 void graph(char *s) /* graph statement */
138 fprintf(stdout, "%s: [\n", graphname);
139 print(); /* pump out previous graph */
140 fprintf(stdout, "\n] %s\n", graphpos);
144 dprintf("into graph with <%s>\n", s);
147 while ((c = *s) == ' ' || c == '\t')
150 ERROR "no name on graph statement" WARNING;
151 if (!isupper((uchar)s[0]))
152 ERROR "graph name %s must be capitalized", s WARNING;
153 for (p=graphname; (c = *s) != ' ' && c != '\t' && c != '\0'; )
157 dprintf("graphname = <%s>, graphpos = <%s>\n", graphname, graphpos);
162 void setup(void) /* done at each .G1 */
164 static int firstG1 = 0;
168 frame_ht = frame_wid = -1; /* reset in frame() */
169 ticklen = getvar(lookup("ticklen", 0));
172 codegen = synerr = 0;
173 strcpy(graphname, "Graph");
174 strcpy(graphpos, "");
177 void do_first(void) /* done at first .G1: definitions, etc. */
180 extern char *lib_defines;
181 static char buf[100], buf1[100]; /* static because pbstr uses them */
183 extern int getpid(void);
185 snprintf(buf, sizeof buf, "define pid /%d/\n", getpid());
188 if ((fp = fopen(lib_defines, "r")) != NULL) {
189 snprintf(buf1, sizeof buf, "copy \"%s\"\n", lib_defines);
193 fprintf(stderr, "grap warning: can't open %s\n", lib_defines);
198 void reset(void) /* done at each "graph ..." statement */
200 Obj *p, *np, *deflist;
201 extern int tlist, toffside, autodir;
203 curr_coord = dflt_coord;
205 autoticks = LEFT|BOT;
207 tside = tlist = toffside = 0;
211 for (p = objlist; p; p = np) {
213 if (p->type == DEFNAME || p->type == VARNAME) {
232 if ((tfd = fopen(tempfile, "w")) == NULL) {
233 fprintf(stderr, "grap: can't open %s\n", tempfile);