===================================================================
RCS file: /home/cvs/OpenXM_contrib2/asir2000/parse/parse.y,v
retrieving revision 1.16
retrieving revision 1.18
diff -u -p -r1.16 -r1.18
--- OpenXM_contrib2/asir2000/parse/parse.y 2003/05/14 09:18:38 1.16
+++ OpenXM_contrib2/asir2000/parse/parse.y 2003/05/16 09:34:50 1.18
@@ -45,7 +45,7 @@
* DEVELOPER SHALL HAVE NO LIABILITY IN CONNECTION WITH THE USE,
* PERFORMANCE OR NON-PERFORMANCE OF THE SOFTWARE.
*
- * $OpenXM: OpenXM_contrib2/asir2000/parse/parse.y,v 1.15 2003/05/14 06:20:12 noro Exp $
+ * $OpenXM: OpenXM_contrib2/asir2000/parse/parse.y,v 1.17 2003/05/16 07:56:16 noro Exp $
*/
%{
#define malloc(x) GC_malloc(x)
@@ -89,7 +89,7 @@ extern jmp_buf env;
pointer p;
}
-%token STRUCT POINT NEWSTRUCT ANS FDEF PFDEF MODDEF MODEND GLOBAL MGLOBAL CMP OR AND CAR CDR QUOTED
+%token STRUCT POINT NEWSTRUCT ANS FDEF PFDEF MODDEF MODEND GLOBAL MGLOBAL LOCALF CMP OR AND CAR CDR QUOTED
%token DO WHILE FOR IF ELSE BREAK RETURN CONTINUE PARIF MAP RECMAP TIMER GF2NGEN GFPNGEN GFSNGEN GETOPT
%token FOP_AND FOP_OR FOP_IMPL FOP_REPL FOP_EQUIV FOP_NOT LOP
%token
FORMULA UCASE LCASE STR SELF BOPASS
@@ -98,7 +98,7 @@ extern jmp_buf env;
%type
desc rawstr
%type expr pexpr opt
%type stat complex
-%type stats node _node pvars members optlist
+%type stats node _node pvars vars members optlist
%right '=' BOPASS
%right '?' ':'
@@ -132,6 +132,8 @@ stat : tail
{ $$ = 0; }
| GLOBAL { gdef=1; } pvars { gdef=0; } tail
{ $$ = 0; }
+ | LOCALF vars tail
+ { appenduflist($2); $$ = 0; }
| MGLOBAL { mgdef=1; } pvars { mgdef=0; } tail
{ $$ = 0; }
| STRUCT rawstr '{' members '}' tail
@@ -162,7 +164,7 @@ stat : tail
{ $$ = mksnode(3,S_PFDEF,$1,$3,$7); NOPR; }
| PFDEF LCASE '(' node ')'
{ $$ = mksnode(3,S_PFDEF,$2,$4,0); NOPR; }
- | FDEF LCASE { mkpvs(); } '(' node ')' desc '{' stats '}'
+ | FDEF LCASE { mkpvs($2); } '(' node ')' desc '{' stats '}'
{
mkuf($2,asir_infile->name,$5,
mksnode(1,S_CPLX,$9),$1,asir_infile->ln,$7,CUR_MODULE);
@@ -193,6 +195,11 @@ members : rawstr
| members ',' rawstr
{ appendtonode($1,$3,&$$); }
;
+vars : LCASE
+ { MKNODE($$,$1,0); }
+ | vars ',' LCASE
+ { appendtonode($1,$3,&$$); }
+ ;
pvars : UCASE
{ val = (pointer)makepvar($1); MKNODE($$,val,0); }
| pvars ',' UCASE
@@ -268,23 +275,27 @@ pexpr : STR
| LCASE '(' node ')'
{
gen_searchf($1,(FUNC *)&val);
+ print_crossref(val);
$$ = mkfnode(2,I_FUNC,val,mkfnode(1,I_LIST,$3));
}
| LCASE '(' node '|' optlist ')'
{
gen_searchf($1,(FUNC *)&val);
+ print_crossref(val);
$$ = mkfnode(3,I_FUNC_OPT,val,
mkfnode(1,I_LIST,$3),mkfnode(1,I_LIST,$5));
}
| MAP '(' LCASE ',' node ')'
{
gen_searchf($3,(FUNC *)&val);
+ print_crossref(val);
$$ = mkfnode(2,I_MAP,val,mkfnode(1,I_LIST,$5));
}
| RECMAP '(' LCASE ',' node ')'
{
gen_searchf($3,(FUNC *)&val);
+ print_crossref(val);
$$ = mkfnode(2,I_RECMAP,val,mkfnode(1,I_LIST,$5));
}
| LCASE '{' node '}' '(' node ')'