[BACK]Return to parse.y CVS log [TXT][DIR] Up to [local] / OpenXM_contrib2 / asir2000 / parse

Diff for /OpenXM_contrib2/asir2000/parse/parse.y between version 1.16 and 1.18

version 1.16, 2003/05/14 09:18:38 version 1.18, 2003/05/16 09:34:50
Line 45 
Line 45 
  * DEVELOPER SHALL HAVE NO LIABILITY IN CONNECTION WITH THE USE,   * DEVELOPER SHALL HAVE NO LIABILITY IN CONNECTION WITH THE USE,
  * PERFORMANCE OR NON-PERFORMANCE OF THE SOFTWARE.   * PERFORMANCE OR NON-PERFORMANCE OF THE SOFTWARE.
  *   *
  * $OpenXM: OpenXM_contrib2/asir2000/parse/parse.y,v 1.15 2003/05/14 06:20:12 noro Exp $   * $OpenXM: OpenXM_contrib2/asir2000/parse/parse.y,v 1.17 2003/05/16 07:56:16 noro Exp $
 */  */
 %{  %{
 #define malloc(x) GC_malloc(x)  #define malloc(x) GC_malloc(x)
Line 89  extern jmp_buf env;
Line 89  extern jmp_buf env;
         pointer p;          pointer p;
 }  }
   
 %token <i> STRUCT POINT NEWSTRUCT ANS FDEF PFDEF MODDEF MODEND GLOBAL MGLOBAL CMP OR AND CAR CDR QUOTED  %token <i> STRUCT POINT NEWSTRUCT ANS FDEF PFDEF MODDEF MODEND GLOBAL MGLOBAL LOCALF CMP OR AND CAR CDR QUOTED
 %token <i> DO WHILE FOR IF ELSE BREAK RETURN CONTINUE PARIF MAP RECMAP TIMER GF2NGEN GFPNGEN GFSNGEN GETOPT  %token <i> DO WHILE FOR IF ELSE BREAK RETURN CONTINUE PARIF MAP RECMAP TIMER GF2NGEN GFPNGEN GFSNGEN GETOPT
 %token <i> FOP_AND FOP_OR FOP_IMPL FOP_REPL FOP_EQUIV FOP_NOT LOP  %token <i> FOP_AND FOP_OR FOP_IMPL FOP_REPL FOP_EQUIV FOP_NOT LOP
 %token <p> FORMULA UCASE LCASE STR SELF BOPASS  %token <p> FORMULA UCASE LCASE STR SELF BOPASS
Line 98  extern jmp_buf env;
Line 98  extern jmp_buf env;
 %type <p> desc rawstr  %type <p> desc rawstr
 %type <f> expr pexpr opt  %type <f> expr pexpr opt
 %type <s> stat complex  %type <s> stat complex
 %type <n> stats node _node pvars members optlist  %type <n> stats node _node pvars vars members optlist
   
 %right '=' BOPASS  %right '=' BOPASS
 %right '?' ':'  %right '?' ':'
Line 132  stat  : tail
Line 132  stat  : tail
                         { $$ = 0; }                          { $$ = 0; }
                 | GLOBAL { gdef=1; } pvars { gdef=0; } tail                  | GLOBAL { gdef=1; } pvars { gdef=0; } tail
                         { $$ = 0; }                          { $$ = 0; }
                   | LOCALF vars tail
                           { appenduflist($2); $$ = 0; }
                 | MGLOBAL { mgdef=1; } pvars { mgdef=0; } tail                  | MGLOBAL { mgdef=1; } pvars { mgdef=0; } tail
                         { $$ = 0; }                          { $$ = 0; }
                 | STRUCT rawstr '{' members '}' tail                  | STRUCT rawstr '{' members '}' tail
Line 162  stat  : tail
Line 164  stat  : tail
                         { $$ = mksnode(3,S_PFDEF,$1,$3,$7); NOPR; }                          { $$ = mksnode(3,S_PFDEF,$1,$3,$7); NOPR; }
                 | PFDEF LCASE '(' node ')'                  | PFDEF LCASE '(' node ')'
                         { $$ = mksnode(3,S_PFDEF,$2,$4,0); NOPR; }                          { $$ = mksnode(3,S_PFDEF,$2,$4,0); NOPR; }
                 | FDEF LCASE { mkpvs(); } '(' node ')' desc '{' stats '}'                  | FDEF LCASE { mkpvs($2); } '(' node ')' desc '{' stats '}'
                         {                          {
                                 mkuf($2,asir_infile->name,$5,                                  mkuf($2,asir_infile->name,$5,
                                         mksnode(1,S_CPLX,$9),$1,asir_infile->ln,$7,CUR_MODULE);                                          mksnode(1,S_CPLX,$9),$1,asir_infile->ln,$7,CUR_MODULE);
Line 193  members : rawstr
Line 195  members : rawstr
                 | members ',' rawstr                  | members ',' rawstr
                         { appendtonode($1,$3,&$$); }                          { appendtonode($1,$3,&$$); }
                 ;                  ;
   vars    : LCASE
                           { MKNODE($$,$1,0); }
                   | vars ',' LCASE
                           { appendtonode($1,$3,&$$); }
                   ;
 pvars   : UCASE  pvars   : UCASE
                         { val = (pointer)makepvar($1); MKNODE($$,val,0); }                          { val = (pointer)makepvar($1); MKNODE($$,val,0); }
                 | pvars ',' UCASE                  | pvars ',' UCASE
Line 268  pexpr : STR
Line 275  pexpr : STR
                 | LCASE '(' node ')'                  | LCASE '(' node ')'
                         {                          {
                                 gen_searchf($1,(FUNC *)&val);                                  gen_searchf($1,(FUNC *)&val);
                                   print_crossref(val);
                                 $$ = mkfnode(2,I_FUNC,val,mkfnode(1,I_LIST,$3));                                  $$ = mkfnode(2,I_FUNC,val,mkfnode(1,I_LIST,$3));
                         }                          }
   
                 | LCASE '(' node '|' optlist ')'                  | LCASE '(' node '|' optlist ')'
                         {                          {
                                 gen_searchf($1,(FUNC *)&val);                                  gen_searchf($1,(FUNC *)&val);
                                   print_crossref(val);
                                 $$ = mkfnode(3,I_FUNC_OPT,val,                                  $$ = mkfnode(3,I_FUNC_OPT,val,
                                         mkfnode(1,I_LIST,$3),mkfnode(1,I_LIST,$5));                                          mkfnode(1,I_LIST,$3),mkfnode(1,I_LIST,$5));
                         }                          }
                 | MAP '(' LCASE ',' node ')'                  | MAP '(' LCASE ',' node ')'
                         {                          {
                                 gen_searchf($3,(FUNC *)&val);                                  gen_searchf($3,(FUNC *)&val);
                                   print_crossref(val);
                                 $$ = mkfnode(2,I_MAP,val,mkfnode(1,I_LIST,$5));                                  $$ = mkfnode(2,I_MAP,val,mkfnode(1,I_LIST,$5));
                         }                          }
                 | RECMAP '(' LCASE ',' node ')'                  | RECMAP '(' LCASE ',' node ')'
                         {                          {
                                 gen_searchf($3,(FUNC *)&val);                                  gen_searchf($3,(FUNC *)&val);
                                   print_crossref(val);
                                 $$ = mkfnode(2,I_RECMAP,val,mkfnode(1,I_LIST,$5));                                  $$ = mkfnode(2,I_RECMAP,val,mkfnode(1,I_LIST,$5));
                         }                          }
                 | LCASE '{' node '}' '(' node ')'                  | LCASE '{' node '}' '(' node ')'

Legend:
Removed from v.1.16  
changed lines
  Added in v.1.18

FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>