[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.2 and 1.14

version 1.2, 2000/08/21 08:31:47 version 1.14, 2002/12/22 02:08:29
Line 23 
Line 23 
  * shall be made on your publication or presentation in any form of the   * shall be made on your publication or presentation in any form of the
  * results obtained by use of the SOFTWARE.   * results obtained by use of the SOFTWARE.
  * (4) In the event that you modify the SOFTWARE, you shall notify FLL by   * (4) In the event that you modify the SOFTWARE, you shall notify FLL by
  * e-mail at risa-admin@flab.fujitsu.co.jp of the detailed specification   * e-mail at risa-admin@sec.flab.fujitsu.co.jp of the detailed specification
  * for such modification or the source code of the modified part of the   * for such modification or the source code of the modified part of the
  * SOFTWARE.   * SOFTWARE.
  *   *
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.1.1.1 1999/12/03 07:39:12 noro Exp $   * $OpenXM: OpenXM_contrib2/asir2000/parse/parse.y,v 1.13 2002/12/09 00:42:15 noro Exp $
 */  */
 %{  %{
 #define malloc(x) GC_malloc(x)  #define malloc(x) GC_malloc(x)
 #define realloc(x,y) GC_realloc(x,y)  #define realloc(x,y) GC_realloc(x,y)
 #define free(x) GC_free(x)  #define free(x) GC_free(x)
   
 #if defined(THINK_C)  
 #define alloca(x) GC_malloc(x)  
 #endif  
 #if defined(TOWNS)  #if defined(TOWNS)
 #include <alloca.h>  #include <alloca.h>
 #endif  #endif
 #include <ctype.h>  #include <ctype.h>
 #include "ca.h"  #include "ca.h"
 #if !defined(THINK_C)  
 #include <sys/types.h>  #include <sys/types.h>
 #include <sys/stat.h>  #include <sys/stat.h>
 #endif  
 #include "parse.h"  #include "parse.h"
   
 #define NOPR (prresult=0)  #define NOPR (prresult=0)
   
 extern int gdef;  extern int gdef;
 extern SNODE parse_snode;  extern SNODE parse_snode;
 extern int main_parser;  extern int main_parser, allow_create_var;
   
 int prresult;  int prresult;
   
Line 79  static FNODE t;
Line 74  static FNODE t;
 static NODE a,b;  static NODE a,b;
 static NODE2 a2;  static NODE2 a2;
 static pointer val;  static pointer val;
   static QUOTE quote;
 extern jmp_buf env;  extern jmp_buf env;
 %}  %}
   
Line 93  extern jmp_buf env;
Line 89  extern jmp_buf env;
         pointer p;          pointer p;
 }  }
   
 %token <i> STRUCT POINT NEWSTRUCT ANS FDEF PFDEF GLOBAL CMP OR AND CAR CDR  %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 102  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 fields members optlist  %type <n> stats node _node pvars members optlist
   
 %right '=' BOPASS  %right '=' BOPASS
 %right '?' ':'  %right '?' ':'
Line 136  stat  : tail
Line 132  stat  : tail
                         { $$ = 0; }                          { $$ = 0; }
                 | GLOBAL { gdef=1; } pvars { gdef=0; } tail                  | GLOBAL { gdef=1; } pvars { gdef=0; } tail
                         { $$ = 0; }                          { $$ = 0; }
                 | STRUCT rawstr '{' fields '}' tail                  | STRUCT rawstr '{' members '}' tail
                         { structdef($2,$4); $$ = 0; }                          { structdef($2,$4); $$ = 0; }
                 | STRUCT rawstr '{' fields '}' pvars tail  
                         { structdef($2,$4); setstruct($2,$6); $$ = 0; }  
                 | STRUCT rawstr pvars tail  
                         { setstruct($2,$3); $$ = 0; }  
                 | expr tail                  | expr tail
                         { $$ = mksnode(1,S_SINGLE,$1); }                          { $$ = mksnode(1,S_SINGLE,$1); }
                 | complex                  | complex
Line 181  tail : ';' 
Line 173  tail : ';' 
                         { if ( main_parser ) prresult = 1; }                          { if ( main_parser ) prresult = 1; }
                 | '$'                  | '$'
                         { if ( main_parser ) prresult = 0; }                          { if ( main_parser ) prresult = 0; }
   ;
 desc    :  desc    :
                         { $$ = 0; }                          { $$ = 0; }
                 | STR                  | STR
Line 189  desc :
Line 182  desc :
 complex : '{' stats '}'  complex : '{' stats '}'
                         { $$ = mksnode(1,S_CPLX,$2); }                          { $$ = mksnode(1,S_CPLX,$2); }
                 ;                  ;
 fields  :  
                         { $$ = 0; }  
                 | fields members tail  
                         { MKNODE(a,0,$2); appendtonode($1,(pointer)a,&$$); }  
                 | fields STRUCT rawstr members tail  
                         { MKNODE(a,$3,$4); appendtonode($1,(pointer)a,&$$); }  
                 ;  
 members : rawstr  members : rawstr
                         { MKNODE($$,$1,0); }                          { MKNODE($$,$1,0); }
                 | members ',' rawstr                  | members ',' rawstr
Line 244  pexpr : STR
Line 230  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 273  pexpr : STR
Line 261  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 308  pexpr : STR
Line 290  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 341  pexpr : STR
Line 321  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 || allow_create_var )
                                         $$ = mkfnode(2,I_PVAR,makepvar($1),0);                                          $$ = mkfnode(2,I_PVAR,makepvar($1),0);
                                 else {                                  else {
                                         ind = searchpvar($1);                                          ind = searchpvar($1);
Line 366  pexpr : STR
Line 346  pexpr : STR
                                 }                                  }
                         }                          }
                 | pexpr POINT rawstr                  | pexpr POINT rawstr
                         { memberofstruct($1,$3,&$$); }                          { $$ = mkfnode(2,I_POINT,$1,$3); }
                 ;                  ;
 expr    : pexpr  expr    : pexpr
                         { $$ = $1; }                          { $$ = $1; }
Line 385  expr  : pexpr
Line 365  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
Line 426  expr  : pexpr
Line 406  expr  : pexpr
                         { $$ = mkfnode(1,I_EV,$2); }                          { $$ = mkfnode(1,I_EV,$2); }
                 | NEWSTRUCT '(' rawstr ')'                  | NEWSTRUCT '(' rawstr ')'
                         { $$ = mkfnode(1,I_NEWCOMP,(int)structtoindex($3)); }                          { $$ = mkfnode(1,I_NEWCOMP,(int)structtoindex($3)); }
                   | QUOTED '(' expr ')'
                           { MKQUOTE(quote,$3); $$ = mkfnode(1,I_FORMULA,(pointer)quote); }
                 ;                  ;
 %%  %%

Legend:
Removed from v.1.2  
changed lines
  Added in v.1.14

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