[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.17 and 1.21

version 1.17, 2003/05/16 07:56:16 version 1.21, 2003/05/30 00:47:25
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.16 2003/05/14 09:18:38 noro Exp $   * $OpenXM: OpenXM_contrib2/asir2000/parse/parse.y,v 1.20 2003/05/23 00:11:59 noro Exp $
 */  */
 %{  %{
 #define malloc(x) GC_malloc(x)  #define malloc(x) GC_malloc(x)
Line 63 
Line 63 
   
 #define NOPR (prresult=0)  #define NOPR (prresult=0)
   
 extern int gdef,mgdef;  extern int gdef,mgdef,ldef;
 extern SNODE parse_snode;  extern SNODE parse_snode;
 extern int main_parser, allow_create_var;  extern int main_parser, allow_create_var;
   
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 GLOBALF CMP OR AND CAR CDR QUOTED  %token <i> STRUCT POINT NEWSTRUCT ANS FDEF PFDEF MODDEF MODEND
   %token <i> GLOBAL MGLOBAL LOCAL LOCALF CMP OR AND CAR CDR QUOTED COLONCOLON
 %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 102  extern jmp_buf env;
Line 103  extern jmp_buf env;
   
 %right '=' BOPASS  %right '=' BOPASS
 %right '?' ':'  %right '?' ':'
   %left '`'
 %right FOP_NOT  %right FOP_NOT
 %left FOP_EQUIV  %left FOP_EQUIV
 %left FOP_REPL  %left FOP_REPL
Line 131  start  : stat
Line 133  start  : stat
 stat    : tail  stat    : tail
                         { $$ = 0; }                          { $$ = 0; }
                 | GLOBAL { gdef=1; } pvars { gdef=0; } tail                  | GLOBAL { gdef=1; } pvars { gdef=0; } tail
                         { $$ = 0; }                          { $$ = 0; NOPR; }
                 | GLOBALF vars tail  
                         { register_proto($2); $$ = 0; }  
                 | MGLOBAL { mgdef=1; } pvars { mgdef=0; } tail                  | MGLOBAL { mgdef=1; } pvars { mgdef=0; } tail
                         { $$ = 0; }                          { $$ = 0; NOPR; }
                   | LOCAL { ldef=1; } pvars { ldef=0; } tail
                           { $$ = 0; NOPR; }
                   | LOCALF vars tail
                           { appenduflist($2); $$ = 0; NOPR; }
                 | STRUCT rawstr '{' members '}' tail                  | STRUCT rawstr '{' members '}' tail
                         { structdef($2,$4); $$ = 0; }                          { structdef($2,$4); $$ = 0; NOPR; }
                 | expr tail                  | expr tail
                         { $$ = mksnode(1,S_SINGLE,$1); }                          { $$ = mksnode(1,S_SINGLE,$1); }
                 | complex                  | complex
Line 162  stat  : tail
Line 166  stat  : tail
                         { $$ = mksnode(3,S_DO,$1,$2,$5); }                          { $$ = mksnode(3,S_DO,$1,$2,$5); }
                 | LCASE '(' node ')' ':' '=' expr tail                  | LCASE '(' node ')' ':' '=' expr tail
                         { $$ = mksnode(3,S_PFDEF,$1,$3,$7); NOPR; }                          { $$ = mksnode(3,S_PFDEF,$1,$3,$7); NOPR; }
                 | PFDEF LCASE '(' node ')'                  | PFDEF LCASE '(' node ')' tail
                         { $$ = mksnode(3,S_PFDEF,$2,$4,0); NOPR; }                          { $$ = mksnode(3,S_PFDEF,$2,$4,0); NOPR; }
                 | FDEF LCASE { mkpvs($2); } '(' node ')' desc '{' stats '}'                  | FDEF LCASE { mkpvs($2); } '(' { ldef = 1; } node { ldef = -1; } ')' desc '{' stats '}'
                         {                          {
                                 mkuf($2,asir_infile->name,$5,                                  mkuf($2,asir_infile->name,$6,
                                         mksnode(1,S_CPLX,$9),$1,asir_infile->ln,$7,CUR_MODULE);                                          mksnode(1,S_CPLX,$11),$1,asir_infile->ln,$9,CUR_MODULE);
                                 $$ = 0; NOPR;                                  $$ = 0; NOPR;
                         }                          }
                 | MODDEF LCASE tail                  | MODDEF LCASE tail
Line 425  expr  : pexpr
Line 429  expr  : pexpr
                         { $$ = mkfnode(1,I_NEWCOMP,(int)structtoindex($3)); }                          { $$ = mkfnode(1,I_NEWCOMP,(int)structtoindex($3)); }
                 | QUOTED '(' expr ')'                  | QUOTED '(' expr ')'
                         { MKQUOTE(quote,$3); $$ = mkfnode(1,I_FORMULA,(pointer)quote); }                          { MKQUOTE(quote,$3); $$ = mkfnode(1,I_FORMULA,(pointer)quote); }
                   | '`' expr
                           { MKQUOTE(quote,$2); $$ = mkfnode(1,I_FORMULA,(pointer)quote); }
                 ;                  ;
 %%  %%

Legend:
Removed from v.1.17  
changed lines
  Added in v.1.21

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