|
|
1.1 root 1: %Start A str def sc br thru sh eqn
2: %e 1900
3: %k 150
4: %a 2100
5: %o 1650
6: %p 5300
7: %n 750
8:
9: %{
10: #undef input
11: #undef unput
12: #include <ctype.h>
13: #include <math.h>
14: #include "picasso.h"
15: #include "y.tab.h"
16:
17: extern double atof();
18: extern struct symtab symtab[];
19: extern char *filename, *copythru();
20:
21: #define CADD cbuf[clen++]=yytext[0];\
22: if(clen>=CBUFLEN-1) {yyerror("string too long",cbuf); BEGIN A;}
23: #define CBUFLEN 500
24:
25: char cbuf[CBUFLEN];
26: int c, clen, cflag, delim;
27: int ifsw = 0; /* 1 if if statement in progress */
28: %}
29:
30: A [a-zA-Z_]
31: B [a-zA-Z0-9_]
32: D [0-9]
33: WS [ \t]
34:
35: %%
36: switch (yybgin-yysvec-1) { /* witchcraft */
37: case 0:
38: BEGIN A;
39: break;
40: case sc:
41: BEGIN A;
42: return('}');
43: case br:
44: BEGIN A;
45: return(']');
46: }
47:
48: <A>{WS} ;
49: <A>"\\"\n ;
50: <A>\n { return(ST); }
51: <A>";" { return(ST); }
52: <A>"}" { BEGIN sc; return(ST); }
53: <A>"]" { BEGIN br; return(ST); }
54:
55: <A>^".PS".* { if (curfile == infile) yyerror(".PS found inside .PS/.PE"); }
56: <A>^"."P[EFN].* { if (curfile == infile) {
57: yylval.i = yytext[2];
58: PEseen = 1;
59: return(EOF);
60: }
61: }
62: <A>^".EQ".* { BEGIN eqn; eqn_save(yytext); return(ST); }
63: <eqn>^".EN".* { eqn_save(yytext); eqn_gen(TROFF); BEGIN A; return(ST); }
64: <eqn>^.* { eqn_save(yytext); return(ST); }
65: <eqn>\n ;
66: <A>^".".* { yylval.p = tostring(yytext); return(TROFF); }
67:
68: <A>print return(yylval.i = PRINT);
69: <A>show return(yylval.i = SHOW);
70: <A>box return(yylval.i = BOX);
71: <A>circle return(yylval.i = CIRCLE);
72: <A>arc return(yylval.i = ARC);
73: <A>sector return(yylval.i = SECTOR);
74: <A>ellipse return(yylval.i = ELLIPSE);
75: <A>arrow return(yylval.i = ARROW);
76: <A>spline return(yylval.i = SPLINE);
77: <A>line return(yylval.i = LINE);
78: <A>move return(yylval.i = MOVE);
79: <A>psfile return(yylval.i = PSFILE);
80: <A>(block|"[]") return(yylval.i = BLOCK);
81: <A>text return(yylval.i = TEXTOBJ);
82: <A>object return(yylval.i = OBJECT);
83: <A>reset return(RESET);
84: <A>sprintf return(SPRINTF);
85:
86: <A>rot(ate)? return(yylval.i = ROTATE);
87: <A>trans(late)? return(yylval.i = TRANSLATE);
88: <A>scale return(yylval.i = SCALE);
89: <A>reflect return(yylval.i = REFLECT);
90: <A>transform return(yylval.i = TRANSFORM);
91:
92: <A>same return(SAME);
93: <A>between return(BETWEEN);
94: <A>and return(AND);
95:
96: <A>of ;
97: <A>the ;
98: <A>way ;
99:
100: <A>"."(e|east) { yylval.i = EAST; return(CORNER); }
101: <A>"."(r|right) { yylval.i = EAST; return(CORNER); }
102: <A>"."(w|west) { yylval.i = WEST; return(CORNER); }
103: <A>"."(l|left) { yylval.i = WEST; return(CORNER); }
104: <A>"."(n|north) { yylval.i = NORTH; return(CORNER); }
105: <A>"."(t|top) { yylval.i = NORTH; return(CORNER); }
106: <A>"."(s|south) { yylval.i = SOUTH; return(CORNER); }
107: <A>"."(b|bot|bottom) { yylval.i = SOUTH; return(CORNER); }
108: <A>"."(c|center) { yylval.i = CENTER; return(CORNER); }
109: <A>"."(ne|northeast) { yylval.i = NE; return(CORNER); }
110: <A>"."(se|southeast) { yylval.i = SE; return(CORNER); }
111: <A>"."(nw|northwest) { yylval.i = NW; return(CORNER); }
112: <A>"."(sw|southwest) { yylval.i = SW; return(CORNER); }
113: <A>".end" { yylval.i = END; return(CORNER); }
114: <A>".start" { yylval.i = START; return(CORNER); }
115:
116: <A>".first" { yylval.i = 1; return(DOTNTH); }
117: <A>"."{D}+(th|nd|rd|st) { yylval.i = atoi(yytext+1); return(DOTNTH); }
118:
119: <A>top" "+of { yylval.i = NORTH; return(CORNER); }
120: <A>north" "+of { yylval.i = NORTH; return(CORNER); }
121: <A>bottom" "+of { yylval.i = SOUTH; return(CORNER); }
122: <A>south" "+of { yylval.i = SOUTH; return(CORNER); }
123: <A>left" "+of { yylval.i = WEST; return(CORNER); }
124: <A>west" "+of { yylval.i = WEST; return(CORNER); }
125: <A>northwest" "+of { yylval.i = NW; return(CORNER); }
126: <A>southwest" "+of { yylval.i = SW; return(CORNER); }
127: <A>right" "+of { yylval.i = EAST; return(CORNER); }
128: <A>east" "+of { yylval.i = EAST; return(CORNER); }
129: <A>northeast" "+of { yylval.i = NE; return(CORNER); }
130: <A>southeast" "+of { yylval.i = SE; return(CORNER); }
131: <A>center" "+of { yylval.i = CENTER; return(CORNER); }
132: <A>start" "+of { yylval.i = START; return(CORNER); }
133: <A>end" "+of { yylval.i = END; return(CORNER); }
134:
135: <A>fill(ed)? { yylval.i = PCOLOR; return(COLOR); }
136: <A>edge(d)? { yylval.i = LCOLOR; return(COLOR); }
137: <A>label(ed)? { yylval.i = TCOLOR; return(COLOR); }
138:
139: <A>height|ht { yylval.i = HEIGHT; return(ATTR); }
140: <A>width|wid { yylval.i = WIDTH; return(ATTR); }
141: <A>radius|rad { yylval.i = RADIUS; return(ATTR); }
142: <A>diameter|diam { yylval.i = DIAMETER; return(ATTR); }
143: <A>left { yylval.i = LEFT; return(DIR); }
144: <A>right { yylval.i = RIGHT; return(DIR); }
145: <A>up { yylval.i = UP; return(DIR); }
146: <A>down { yylval.i = DOWN; return(DIR); }
147: <A>cw { yylval.i = CW; return(ATTR); }
148: <A>clockwise { yylval.i = CW; return(ATTR); }
149: <A>ccw { yylval.i = CCW; return(ATTR); }
150: <A>noedge { yylval.i = NOEDGE; return(ATTR); }
151: <A>invis(ible)? { yylval.i = NOEDGE; return(ATTR); }
152: <A>layer { yylval.i = LAYER; return(ATTR); }
153: <A>weight|wt { yylval.i = LWEIGHT; return(ATTR); }
154: <A>dot(ted)? return(yylval.i = DOT);
155: <A>dashpat return(yylval.i = DASHPAT);
156: <A>dash(ed)? return(yylval.i = DASH);
157: <A>chop return(yylval.i = CHOP);
158: <A>size return(yylval.i = SIZE);
159: <A>space return(yylval.i = SPACE);
160: <A>font return(yylval.i = FONT);
161: <A>setrgb return(yylval.i = RGB);
162: <A>setfont return(yylval.i = SETFONT);
163:
164: <A>ljust { yylval.i = LJUST; return TEXTATTR; }
165: <A>rjust { yylval.i = RJUST; return TEXTATTR; }
166: <A>above { yylval.i = ABOVE; return TEXTATTR; }
167: <A>below { yylval.i = BELOW; return TEXTATTR; }
168: <A>center { yylval.i = CENTER; return TEXTATTR; }
169:
170: <A>"<-" { yylval.i = HEAD1; return(HEAD); }
171: <A>"->" { yylval.i = HEAD2; return(HEAD); }
172: <A>"<->" { yylval.i = HEAD12; return(HEAD); }
173:
174: <A>".x" return(yylval.i = DOTX);
175: <A>".y" return(yylval.i = DOTY);
176: <A>"."(ht|height) return(yylval.i = DOTHT);
177: <A>"."(wid|width) return(yylval.i = DOTWID);
178: <A>"."(rad|radius) return(yylval.i = DOTRAD);
179:
180: <A>from return(yylval.i = FROM);
181: <A>to return(yylval.i = TO);
182: <A>touch(ing)? return(yylval.i = LOCUS);
183: <A>at return(yylval.i = AT);
184: <A>about return(yylval.i = AT);
185: <A>by return(yylval.i = BY);
186: <A>with return(yylval.i = WITH);
187: <A>last return(yylval.i = LAST);
188: <A>del(ete)? return(yylval.i = DELETE);
189:
190: <A>abs return(ABS);
191: <A>ln return(LOG);
192: <A>log return(LOG10);
193: <A>exp return(EXP);
194: <A>pow return(POW);
195: <A>sin return(SIN);
196: <A>cos return(COS);
197: <A>atan2 return(ATAN2);
198: <A>sqrt return(SQRT);
199: <A>rand return(RAND);
200: <A>max return(MAX);
201: <A>min return(MIN);
202: <A>int return(INT);
203:
204: <A>"==" return(EQ);
205: <A>">=" return(GE);
206: <A>"<=" return(LE);
207: <A>"!=" return(NEQ);
208: <A>">" return(GT);
209: <A>"<" return(LT);
210: <A>"&&" return(ANDAND);
211: <A>"||" return(OROR);
212: <A>"!" return(NOT);
213:
214: <A>Here return(yylval.i = HERE);
215:
216: <A>for { return(FOR); }
217: <A>^_Endfor\n { endfor(); }
218: <A>do { yylval.p = delimstr("loop body"); return(DOSTR); }
219:
220: <A>dup(licate)? return(DUP);
221: <A>copy|include return(COPY);
222: <A>(thru|through){WS}+ { BEGIN thru; return(THRU); }
223: <thru>{A}{B}*|. { yylval.p = copythru(yytext); BEGIN A; return(DEFNAME); }
224: <A>until return(UNTIL);
225:
226: <A>if { ifsw = 1; return(IF); }
227: <A>then { if (!ifsw) { yylval.i = THEN; return(ATTR); }
228: yylval.p = delimstr("then part"); ifsw = 0;
229: return(THENSTR); }
230: <A>else { yylval.p = delimstr("else part"); return(ELSESTR); }
231:
232: <A>sh{WS}+ { BEGIN sh;
233: if ((delim = input()) == '{') delim = '}';
234: /* no nested {} */
235: shell_init(); }
236: <sh>{A}{B}* { struct symtab *p;
237: if (yytext[0] == delim) {
238: shell_exec();
239: BEGIN A;
240: } else {
241: p = lookup(yytext, 0);
242: if (p != NULL && p->s_type == DEFNAME) {
243: c = input();
244: unput(c);
245: if (c == '(')
246: dodef(p);
247: else
248: pbstr(p->s_val.p);
249: } else
250: shell_text(yytext);
251: }
252: }
253: <sh>.|\n { if (yytext[0] == delim) {
254: shell_exec();
255: BEGIN A;
256: } else
257: shell_text(yytext);
258: }
259:
260: <A>define{WS}+ { BEGIN def; }
261: <def>{A}{B}* { definition(yytext); BEGIN A; }
262: <A>undef(ine)?{WS}+{A}{B}* { undefine(yytext); }
263:
264: <A>first { yylval.i = 1; return(NTH); }
265: <A>{D}+(th|nd|rd|st) { yylval.i = atoi(yytext); return(NTH); }
266: <A>({D}+("."?){D}*|"."{D}+)((e|E)("+"|-)?{D}+)?d {
267: yylval.f = atof(yytext)*M_PI/180.; return(NUMBER); }
268: <A>({D}+("."?){D}*|"."{D}+)((e|E)("+"|-)?{D}+)?i? {
269: yylval.f = atof(yytext); return(NUMBER); }
270:
271: <A>{A}{B}* { struct symtab *p;
272: p = lookup(yytext);
273: if (p != NULL && p->s_type == DEFNAME) {
274: c = input();
275: unput(c);
276: if (c == '(') /* it's name(...) */
277: dodef(p);
278: else /* no argument list */
279: pbstr(p->s_val);
280: } else {
281: yylval.p = tostring(yytext);
282: if (strcmp(yytext,"textsize")==0) return(TEXTVAR);
283: else if (islower(yytext[0])) return(VARNAME);
284: else return(PLACENAME);
285: }
286: }
287:
288: <A>\" { BEGIN str; clen=0; }
289: <str>\" { cbuf[clen]=0;
290: yylval.p = tostring(cbuf);
291: BEGIN A;
292: return(TEXT);
293: }
294: <str>\n { yyerror("newline in string"); BEGIN A; return(ST); }
295: <str>"\\\"" { cbuf[clen++]='"'; }
296: <str>"\\"t { cbuf[clen++]='\t'; }
297: <str>"\\\\" { cbuf[clen++]='\\'; }
298: <str>. { CADD; }
299:
300: <A>#.* ;
301:
302: <A>. return(yylval.i = yytext[0]);
303:
304: %%
This archive runs on limited infrastructure. Preserving old code on modern bandwidth. Automated agents are requested to crawl responsibly.