[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.26 and 1.38

version 1.26, 2005/04/07 08:33:12 version 1.38, 2018/03/28 05:27:22
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.25 2004/06/21 09:05:16 noro Exp $   * $OpenXM: OpenXM_contrib2/asir2000/parse/parse.y,v 1.37 2017/08/31 02:36:21 noro Exp $
 */  */
 %{  %{
 #define malloc(x) GC_malloc(x)  #define malloc(x) Risa_GC_malloc(x)
 #define realloc(x,y) GC_realloc(x,y)  #define realloc(x,y) Risa_GC_realloc(x,y)
 #define free(x) GC_free(x)  #define free(x) Risa_GC_free(x)
   
 #if defined(TOWNS)  #if defined(TOWNS)
 #include <alloca.h>  #include <alloca.h>
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 157  stat  : tail
Line 157  stat  : tail
                 | CONTINUE tail                  | CONTINUE tail
                         { $$ = mksnode(0,S_CONTINUE); }                          { $$ = mksnode(0,S_CONTINUE); }
                 | RETURN tail                  | RETURN tail
                         { $$ = mksnode(1,S_RETURN,0); }                          { $$ = mksnode(1,S_RETURN,NULLP); }
                 | RETURN expr tail                  | RETURN expr tail
                         { $$ = mksnode(1,S_RETURN,$2); }                          { $$ = mksnode(1,S_RETURN,$2); }
                 | IF '(' node ')' stat                  | IF '(' node ')' stat
                         { $$ = mksnode(4,S_IFELSE,$1,$3,$5,0); $5?$$->ln=$5->ln:0; NOPR; }                          { $$ = mksnode(4,S_IFELSE,$1,$3,$5,NULLP); $5?$$->ln=$5->ln:0; NOPR; }
                 | IF '(' node ')' stat ELSE stat                  | IF '(' node ')' stat ELSE stat
                         { $$ = mksnode(4,S_IFELSE,$1,$3,$5,$7); $7?$$->ln=$7->ln:0; NOPR; }                          { $$ = mksnode(4,S_IFELSE,$1,$3,$5,$7); $7?$$->ln=$7->ln:0; NOPR; }
                 | FOR '(' node ';' node ';' node ')' stat                  | FOR '(' node ';' node ';' node ')' stat
                         { $$ = mksnode(5,S_FOR,$1,$3,$5?$5:ONENODE,$7,$9); $9?$$->ln=$9->ln:0; NOPR; }                          { $$ = mksnode(5,S_FOR,$1,$3,$5?$5:ONENODE,$7,$9); $9?$$->ln=$9->ln:0; NOPR; }
                 | 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,NULLP,$3,NULLP,$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
                         { $$ = mksnode(3,S_PFDEF,$2,$4,0); NOPR; }                          { $$ = mksnode(3,S_PFDEF,$2,$4,NULLP); NOPR; }
                 | FDEF LCASE { mkpvs($2); } '(' { ldef = 1; } node { ldef = -1; } ')' desc '{' stats '}'                  | FDEF LCASE { mkpvs($2); } '(' { ldef = 1; } node { ldef = -1; } ')' desc '{' stats '}'
                         {                          {
                                 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,NULLP); NOPR; }
                 | error tail                  | error tail
                         { yyerrok; $$ = 0; }                          { yyerrok; $$ = 0; }
                 ;                  ;
Line 261  pexpr : STR
Line 265  pexpr : STR
   
                                 searchf(noargsysf,$1,&f);                                  searchf(noargsysf,$1,&f);
                                 if ( f )                                  if ( f )
                                          $$ = mkfnode(2,I_FUNC,f,0);                                           $$ = mkfnode(2,I_FUNC,f,NULLP);
                                 else {                                  else {
                                         searchc($1,&f);                                          searchc($1,&f);
                                         if ( f )                                          if ( f )
                                                 $$ = mkfnode(2,I_FUNC,f,mkfnode(1,I_LIST,0));                                                  $$ = mkfnode(2,I_FUNC,f,mkfnode(1,I_LIST,NULLP));
                                         else {                                          else {
                                                 gen_searchf_searchonly($1,(FUNC *)&f);                                                  gen_searchf_searchonly($1,(FUNC *)&f,1);
                                                 if ( f )                                                  if ( f )
                                                         makesrvar(f,(P *)&val);                                                          makesrvar(f,(P *)&val);
                                                 else                                                  else
Line 282  pexpr : STR
Line 286  pexpr : STR
                                 print_crossref(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);
Line 305  pexpr : STR
Line 308  pexpr : STR
                 | LCASE '{' node '}' '(' node ')'                  | LCASE '{' node '}' '(' node ')'
                         {                          {
                                 searchpf($1,(FUNC *)&val);                                  searchpf($1,(FUNC *)&val);
                                 $$ = mkfnode(2,I_PFDERIV,val,mkfnode(1,I_LIST,$6),mkfnode(1,I_LIST,$3));                                  $$ = mkfnode(3,I_PFDERIV,val,mkfnode(1,I_LIST,$6),mkfnode(1,I_LIST,$3));
                         }                          }
                 | GETOPT '(' rawstr ')'                  | GETOPT '(' rawstr ')'
                         {                          {
Line 313  pexpr : STR
Line 316  pexpr : STR
                         }                          }
                 | GETOPT '(' ')'                  | GETOPT '(' ')'
                         {                          {
                                 $$ = mkfnode(2,I_GETOPT,0);                                  $$ = mkfnode(2,I_GETOPT,NULLP);
                         }                          }
                 | TIMER '(' expr ',' expr ',' expr ')'                  | TIMER '(' expr ',' expr ',' expr ')'
                         {                          {
Line 324  pexpr : STR
Line 327  pexpr : STR
                                 searchf(parif,$3,(FUNC *)&val);                                  searchf(parif,$3,(FUNC *)&val);
                                 if ( !val )                                  if ( !val )
                                         mkparif($3,(FUNC *)&val);                                          mkparif($3,(FUNC *)&val);
                                 $$ = mkfnode(2,I_FUNC,val,0);                                  $$ = mkfnode(2,I_FUNC,val,NULLP);
                         }                          }
                 | PARIF '(' LCASE ',' node ')'                  | PARIF '(' LCASE ',' node ')'
                         {                          {
Line 335  pexpr : STR
Line 338  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),NULLP);
                         }                          }
                   | '('  '*' expr ')' '(' node '|' optlist ')'
                           {
                                   $$ = mkfnode(3,I_IFUNC,$3,mkfnode(1,I_LIST,$6),
                                           mkfnode(1,I_LIST,$8));
                           }
                 | UCASE '(' node ')'                  | UCASE '(' node ')'
                         {                          {
                                 if ( main_parser || allow_create_var )                                  if ( main_parser || allow_create_var )
                                         t = mkfnode(2,I_PVAR,makepvar($1),0);                                          t = mkfnode(2,I_PVAR,makepvar($1),NULLP);
                                 else {                                  else {
                                         ind = searchpvar($1);                                          ind = searchpvar($1);
                                         if ( ind == -1 ) {                                          if ( ind == -1 ) {
                                                 fprintf(stderr,"%s : no such variable.\n",$1);                                                  fprintf(stderr,"%s : no such variable.\n",$1);
                                                 YYABORT;                                                  YYABORT;
                                         } else                                          } else
                                                 t = mkfnode(2,I_PVAR,ind,0);                                                  t = mkfnode(2,I_PVAR,ind,NULLP);
                                 }                                  }
                                 $$ = mkfnode(2,I_IFUNC,t,mkfnode(1,I_LIST,$3));                                  $$ = mkfnode(2,I_IFUNC,t,mkfnode(1,I_LIST,$3));
                         }                          }
Line 360  pexpr : STR
Line 368  pexpr : STR
                 | UCASE                  | UCASE
                         {                          {
                                 if ( main_parser || allow_create_var )                                  if ( main_parser || allow_create_var )
                                         $$ = mkfnode(2,I_PVAR,makepvar($1),0);                                          $$ = mkfnode(2,I_PVAR,makepvar($1),NULLP);
                                 else {                                  else {
                                         ind = searchpvar($1);                                          ind = searchpvar($1);
                                         if ( ind == -1 ) {                                          if ( ind == -1 ) {
                                                 fprintf(stderr,"%s : no such variable.\n",$1);                                                  fprintf(stderr,"%s : no such variable.\n",$1);
                                                 YYABORT;                                                  YYABORT;
                                         } else                                          } else
                                                 $$ = mkfnode(2,I_PVAR,ind,0);                                                  $$ = mkfnode(2,I_PVAR,ind,NULLP);
                                 }                                  }
                         }                          }
                 | pexpr '[' expr ']'                  | pexpr '[' expr ']'
Line 386  pexpr : STR
Line 394  pexpr : STR
 expr    : pexpr  expr    : pexpr
                         { $$ = $1; }                          { $$ = $1; }
                 | '(' STRUCT rawstr ')' pexpr                  | '(' STRUCT rawstr ')' pexpr
                         { $$ = mkfnode(3,I_CAST,structtoindex($3),$5,0); }                          { $$ = mkfnode(3,I_CAST,structtoindex($3),$5,NULLP); }
                 | expr '=' expr                  | expr '=' expr
                         { $$ = mkfnode(2,I_ASSPVAR,$1,$3); }                          { $$ = mkfnode(2,I_ASSPVAR,$1,$3); }
                 | expr BOPASS expr                  | expr BOPASS expr
Line 417  expr  : pexpr
Line 425  expr  : pexpr
                         { $$ = mkfnode(3,I_COP,$2,$1,$3); }                          { $$ = mkfnode(3,I_COP,$2,$1,$3); }
                 | '!' expr                  | '!' expr
                         { $$ = mkfnode(1,I_NOT,$2); }                          { $$ = mkfnode(1,I_NOT,$2); }
                   | expr '!'
                           {
                                   gen_searchf("factorial",(FUNC *)&val);
                                   print_crossref(val);
                                   MKNODE(a,$1,0);
                                   $$ = mkfnode(2,I_FUNC,val,mkfnode(1,I_LIST,a));
                           }
                 | expr OR expr                  | expr OR expr
                         { $$ = mkfnode(2,I_OR,$1,$3); }                          { $$ = mkfnode(2,I_OR,$1,$3); }
                 | expr AND expr                  | expr AND expr
                         { $$ = mkfnode(2,I_AND,$1,$3); }                          { $$ = mkfnode(2,I_AND,$1,$3); }
                 | FOP_NOT expr                  | FOP_NOT expr
                         { $$ = mkfnode(3,I_LOP,$1,$2,0); }                          { $$ = mkfnode(3,I_LOP,$1,$2,NULLP); }
                 | expr FOP_AND expr                  | expr FOP_AND expr
                         { $$ = mkfnode(3,I_LOP,$2,$1,$3); }                          { $$ = mkfnode(3,I_LOP,$2,$1,$3); }
                 | expr FOP_OR expr                  | expr FOP_OR expr
Line 439  expr  : pexpr
Line 454  expr  : pexpr
                         { $$ = mkfnode(3,I_CE,$1,$3,$5); }                          { $$ = mkfnode(3,I_CE,$1,$3,$5); }
                 | '<' node '>'                  | '<' node '>'
                         { $$ = mkfnode(1,I_EV,$2); }                          { $$ = mkfnode(1,I_EV,$2); }
                   | '<' node ':' expr '>'
                           {
           $$ = mkfnode(2,I_EVM,$2,$4);
         }
                 | NEWSTRUCT '(' rawstr ')'                  | NEWSTRUCT '(' rawstr ')'
                         { $$ = 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); }
                   | '[' node '|' expr ']'
                           { $$ = mkfnode(2,I_CONS,$2,$4); }
                 | '`' expr                  | '`' expr
                         { MKQUOTE(quote,$2); $$ = mkfnode(1,I_FORMULA,(pointer)quote); }                          { MKQUOTE(quote,$2); $$ = mkfnode(1,I_FORMULA,(pointer)quote); }
                 ;                  ;

Legend:
Removed from v.1.26  
changed lines
  Added in v.1.38

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