[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.25 and 1.28

version 1.25, 2004/06/21 09:05:16 version 1.28, 2005/08/24 06:28:39
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.24 2004/06/18 05:57:00 noro Exp $   * $OpenXM: OpenXM_contrib2/asir2000/parse/parse.y,v 1.27 2005/07/27 04:35:11 noro Exp $
 */  */
 %{  %{
 #define malloc(x) GC_malloc(x)  #define malloc(x) GC_malloc(x)
Line 67  extern int gdef,mgdef,ldef;
Line 67  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;
   
 int prresult;  int prresult,saveresult;
   
 static int ind;  static int ind;
 static FNODE t;  static FNODE t;
Line 169  stat  : tail
Line 169  stat  : tail
                 | WHILE '(' node ')' stat                  | WHILE '(' node ')' stat
                         { $$ = mksnode(5,S_FOR,$1,0,$3,0,$5); $5?$$->ln=$5->ln:0; NOPR; }                          { $$ = mksnode(5,S_FOR,$1,0,$3,0,$5); $5?$$->ln=$5->ln:0; NOPR; }
                 | DO stat WHILE '(' node ')' tail                  | DO stat WHILE '(' node ')' tail
                         { $$ = mksnode(3,S_DO,$1,$2,$5); }                          { $$ = mksnode(3,S_DO,$1,$2,$5); NOPR; }
                 | 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 ')' tail                  | PFDEF LCASE '(' node ')' tail
Line 178  stat  : tail
Line 178  stat  : tail
                         {                          {
                                 mkuf($2,asir_infile->name,$6,                                  mkuf($2,asir_infile->name,$6,
                                         mksnode(1,S_CPLX,$11),$1,asir_infile->ln,$9,CUR_MODULE);                                          mksnode(1,S_CPLX,$11),$1,asir_infile->ln,$9,CUR_MODULE);
                                 $$ = 0; NOPR;                                  $$ = 0; NOPR;
                         }                          }
                 | MODDEF LCASE tail                  | MODDEF LCASE tail
                         { CUR_MODULE = mkmodule($2); MPVS = CUR_MODULE->pvs; $$ = 0; NOPR; }                          {
                                   CUR_MODULE = mkmodule($2);
                                   MPVS = CUR_MODULE->pvs;
                                   $$ = mksnode(1,S_MODULE,CUR_MODULE); NOPR;
                           }
                 | MODEND tail                  | MODEND tail
                         { CUR_MODULE = 0; MPVS = 0; $$ = 0; NOPR; }                          { CUR_MODULE = 0; MPVS = 0; $$ = mksnode(1,S_MODULE,0); NOPR; }
                 | error tail                  | error tail
                         { yyerrok; $$ = 0; }                          { yyerrok; $$ = 0; }
                 ;                  ;
Line 336  pexpr : STR
Line 340  pexpr : STR
                 | '('  '*' expr ')' '(' node ')'                  | '('  '*' expr ')' '(' node ')'
                         {                          {
                                 $$ = mkfnode(2,I_IFUNC,$3,mkfnode(1,I_LIST,$6));                                  $$ = mkfnode(2,I_IFUNC,$3,mkfnode(1,I_LIST,$6));
                           }
                   | UCASE '(' node ')'
                           {
                                   if ( main_parser || allow_create_var )
                                           t = mkfnode(2,I_PVAR,makepvar($1),0);
                                   else {
                                           ind = searchpvar($1);
                                           if ( ind == -1 ) {
                                                   fprintf(stderr,"%s : no such variable.\n",$1);
                                                   YYABORT;
                                           } else
                                                   t = mkfnode(2,I_PVAR,ind,0);
                                   }
                                   $$ = mkfnode(2,I_IFUNC,t,mkfnode(1,I_LIST,$3));
                         }                          }
                 | CAR '(' expr ')'                  | CAR '(' expr ')'
                         { $$ = mkfnode(1,I_CAR,$3); }                          { $$ = mkfnode(1,I_CAR,$3); }

Legend:
Removed from v.1.25  
changed lines
  Added in v.1.28

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