[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.6 and 1.12

version 1.6, 2001/04/20 02:34:24 version 1.12, 2001/10/03 01:47:31
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.5 2000/12/05 01:24:57 noro Exp $   * $OpenXM: OpenXM_contrib2/asir2000/parse/parse.y,v 1.11 2001/09/05 09:01:28 noro Exp $
 */  */
 %{  %{
 #define malloc(x) GC_malloc(x)  #define malloc(x) GC_malloc(x)
Line 90  extern jmp_buf env;
Line 90  extern jmp_buf env;
 }  }
   
 %token <i> STRUCT POINT NEWSTRUCT ANS FDEF PFDEF GLOBAL CMP OR AND CAR CDR QUOTED  %token <i> STRUCT POINT NEWSTRUCT ANS FDEF PFDEF GLOBAL CMP OR AND CAR CDR QUOTED
 %token <i> DO WHILE FOR IF ELSE BREAK RETURN CONTINUE PARIF MAP TIMER GF2NGEN GFPNGEN 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
 %token <p> '+' '-' '*' '/' '^' '%'  %token <p> '+' '-' '*' '/' '^' '%'
Line 229  pexpr : STR
Line 229  pexpr : STR
                         { $$ = mkfnode(0,I_GF2NGEN); }                          { $$ = mkfnode(0,I_GF2NGEN); }
                 | GFPNGEN                  | GFPNGEN
                         { $$ = mkfnode(0,I_GFPNGEN); }                          { $$ = mkfnode(0,I_GFPNGEN); }
                   | GFSNGEN
                           { $$ = mkfnode(0,I_GFSNGEN); }
                 | LCASE                  | LCASE
                         {                          {
                                 FUNC f;                                  FUNC f;
Line 258  pexpr : STR
Line 260  pexpr : STR
                         }                          }
                 | LCASE '(' node ')'                  | LCASE '(' node ')'
                         {                          {
                                 searchf(sysf,$1,(FUNC *)&val);                                  gen_searchf($1,(FUNC *)&val);
                                 if ( !val )  
                                         searchf(ubinf,$1,(FUNC *)&val);  
                                 if ( !val )  
                                         searchpf($1,(FUNC *)&val);  
                                 if ( !val )  
                                         searchf(usrf,$1,(FUNC *)&val);  
                                 if ( !val )  
                                         appenduf($1,(FUNC *)&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 ')'
                         {                          {
                                 searchf(sysf,$1,(FUNC *)&val);                                  gen_searchf($1,(FUNC *)&val);
                                 if ( !val )  
                                         searchf(ubinf,$1,(FUNC *)&val);  
                                 if ( !val )  
                                         searchpf($1,(FUNC *)&val);  
                                 if ( !val )  
                                         searchf(usrf,$1,(FUNC *)&val);  
                                 if ( !val )  
                                         appenduf($1,(FUNC *)&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 ')'
                           {
                                   gen_searchf($3,(FUNC *)&val);
                                   $$ = mkfnode(2,I_MAP,val,mkfnode(1,I_LIST,$5));
                           }
                   | RECMAP '(' LCASE ',' node ')'
                           {
                                   gen_searchf($3,(FUNC *)&val);
                                   $$ = mkfnode(2,I_RECMAP,val,mkfnode(1,I_LIST,$5));
                           }
                 | LCASE '{' node '}' '(' node ')'                  | LCASE '{' node '}' '(' node ')'
                         {                          {
                                 searchpf($1,(FUNC *)&val);                                  searchpf($1,(FUNC *)&val);
Line 293  pexpr : STR
Line 289  pexpr : STR
                         {                          {
                                 $$ = mkfnode(2,I_GETOPT,$3);                                  $$ = mkfnode(2,I_GETOPT,$3);
                         }                          }
                 | MAP '(' LCASE ',' node ')'                  | GETOPT '(' ')'
                         {                          {
                                 searchf(sysf,$3,(FUNC *)&val);                                  $$ = mkfnode(2,I_GETOPT,0);
                                 if ( !val )  
                                         searchf(ubinf,$3,(FUNC *)&val);  
                                 if ( !val )  
                                         searchpf($3,(FUNC *)&val);  
                                 if ( !val )  
                                         searchf(usrf,$3,(FUNC *)&val);  
                                 if ( !val )  
                                         appenduf($3,(FUNC *)&val);  
                                 $$ = mkfnode(2,I_MAP,val,mkfnode(1,I_LIST,$5));  
                         }                          }
                 | TIMER '(' expr ',' expr ',' expr ')'                  | TIMER '(' expr ',' expr ',' expr ')'
                         {                          {
                                 $$ = mkfnode(3,I_TIMER,$3,$5,$7);                                  $$ = mkfnode(3,I_TIMER,$3,$5,$7);
                         }                          }
                   | PARIF '(' LCASE ')'
                           {
                                   searchf(parif,$3,(FUNC *)&val);
                                   if ( !val )
                                           mkparif($3,(FUNC *)&val);
                                   $$ = mkfnode(2,I_FUNC,val,0);
                           }
                 | PARIF '(' LCASE ',' node ')'                  | PARIF '(' LCASE ',' node ')'
                         {                          {
                                 searchf(parif,$3,(FUNC *)&val);                                  searchf(parif,$3,(FUNC *)&val);
Line 326  pexpr : STR
Line 320  pexpr : STR
                 | CDR '(' expr ')'                  | CDR '(' expr ')'
                         { $$ = mkfnode(1,I_CDR,$3); }                          { $$ = mkfnode(1,I_CDR,$3); }
                 | '(' expr ')'                  | '(' expr ')'
                         { $$ = $2; }                          { $$ = mkfnode(1,I_PAREN,$2); }
                 | UCASE                  | UCASE
                         {                          {
                                 if ( main_parser )                                  if ( main_parser )
Line 370  expr  : pexpr
Line 364  expr  : pexpr
                 | '+' expr      %prec PLUS                  | '+' expr      %prec PLUS
                         { $$ = $2; }                          { $$ = $2; }
                 | '-' expr      %prec MINUS                  | '-' expr      %prec MINUS
                         { $$ = mkfnode(3,I_BOP,$1,0,$2); }                          { $$ = mkfnode(1,I_MINUS,$2); }
                 | expr '+' expr                  | expr '+' expr
                         { $$ = mkfnode(3,I_BOP,$2,$1,$3); }                          { $$ = mkfnode(3,I_BOP,$2,$1,$3); }
                 | expr '-' expr                  | expr '-' expr

Legend:
Removed from v.1.6  
changed lines
  Added in v.1.12

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