updated lookups to return undefined entry if invalid
This commit is contained in:
@ -201,60 +201,70 @@ expression:
|
||||
$$=strdup("undefined");}else{$$=$2;}}
|
||||
|
||||
| NOT expression {printf("not expression\n"); if(strcmp($2,"Boolean")==0){$$=$2;}else{$$=strdup("undefined");
|
||||
printf("mismatch at line %d and column %d\n",@1.first_line,@1.first_column);}}
|
||||
printf("mismatch at line %d and column %d. Invalid type being negated is %s\n",
|
||||
@1.first_line,@1.first_column,$2);}}
|
||||
|
||||
| expression ADD expression
|
||||
{printf("add expression\n");if(strcmp($1,$3)==0 && strcmp($1,"integer")==0){$$=strdup("integer");}
|
||||
else{printf("mismatch at line %d and column %d\n",@2.first_line,@2.first_column);
|
||||
else{printf("mismatch at line %d and column %d. Invalid types %s and %s.\n",
|
||||
@2.first_line,@2.first_column,$1,$3);
|
||||
$$=strdup("undefined");}}
|
||||
|
||||
| expression SUB_OR_NEG expression
|
||||
{printf("sub or neg expression\n");if(strcmp($1,$3)==0 &&strcmp($1,"integer")==0){$$=strdup("integer");}
|
||||
else{printf("mismatch at line %d and column %d\n",@2.first_line,@2.first_column);
|
||||
else{printf("mismatch at line %d and column %d. Invalid types %s and %s.\n",
|
||||
@2.first_line,@2.first_column,$1,$3);
|
||||
$$=strdup("undefined");}}
|
||||
|
||||
| expression MUL expression
|
||||
{printf("multiply expression\n");
|
||||
if(strcmp($1,$3)==0 &&strcmp($1,"integer")==0){$$=strdup("integer");}
|
||||
else{printf("mismatch at line %d and column %d\n",@2.first_line,@2.first_column);
|
||||
else{printf("mismatch at line %d and column %d. Invalid types %s and %s.\n",
|
||||
@2.first_line,@2.first_column,$1,$3);
|
||||
$$=strdup("undefined");}}
|
||||
|
||||
| expression DIV expression
|
||||
{printf("divide expression\n");if(strcmp($1,$3)==0 && strcmp($1,"integer")==0){$$=strdup("integer");}
|
||||
else{printf("mismatch at line %d and column %d\n",@2.first_line,@2.first_column);
|
||||
else{printf("mismatch at line %d and column %d. Invalid types %s and %s.\n",
|
||||
@2.first_line,@2.first_column,$1,$3);
|
||||
$$=strdup("undefined");}}
|
||||
|
||||
| expression REM expression
|
||||
{printf("remainder expression\n");if(strcmp($1,$3)==0 && strcmp($1,"integer")==0){$$=strdup("integer");}
|
||||
else{printf("mismatch at line %d and column %d\n",@2.first_line,@2.first_column);
|
||||
else{printf("mismatch at line %d and column %d. Invalid types %s and %s.\n",
|
||||
@2.first_line,@2.first_column,$1,$3);
|
||||
$$=strdup("undefined");}}
|
||||
|
||||
| expression AND expression
|
||||
{printf("AND expression\n");if(strcmp($1,$3)==0 && strcmp($1,"Boolean")==0){$$=strdup("Boolean");}
|
||||
else{printf("mismatch at line %d and column %d\n",@2.first_line,@2.first_column);
|
||||
else{printf("mismatch at line %d and column %d. Invalid types %s and %s.\n",
|
||||
@2.first_line,@2.first_column,$1,$3);
|
||||
$$=strdup("undefined");}}
|
||||
|
||||
| expression OR expression
|
||||
{printf("OR\n");if(strcmp($1,$3)==0 &&
|
||||
strcmp($1,"Boolean")==0){$$=strdup("Boolean");}
|
||||
else{printf("mismatch at line %d and column %d\n",@2.first_line,@2.first_column);
|
||||
else{printf("mismatch at line %d and column %d. Invalid types %s and %s.\n",
|
||||
@2.first_line,@2.first_column,$1,$3);
|
||||
$$=strdup("undefined");}}
|
||||
|
||||
| expression LESS_THAN expression
|
||||
{printf("less than expression\n");if(strcmp($1,$3)==0 &&
|
||||
strcmp($1,"integer")==0){$$=strdup("Boolean");}
|
||||
else{printf("mismatch at line %d and column %d\n",@2.first_line,@2.first_column);
|
||||
else{printf("mismatch at line %d and column %d. Invalid types %s and %s.\n",
|
||||
@2.first_line,@2.first_column,$1,$3);
|
||||
$$=strdup("undefined");}}
|
||||
|
||||
| expression EQUAL_TO expression {printf("equals check expression\n");
|
||||
if(strcmp($1,$3)==0){$$=strdup("Boolean");}
|
||||
else if((strcmp($1,"array")==0||strcmp($1,"record")==0||
|
||||
strcmp($1,"function type primitive")==0) && (strcmp($3,"address")==0)){$$=strdup("Boolean");}
|
||||
else{printf("mismatch at line %d and column %d\n",@2.first_line,@2.first_column);$$=strdup("undefined");}}
|
||||
else{printf("mismatch at line %d and column %d. Invalid types %s and %s\n",
|
||||
@2.first_line,@2.first_column,$1,$3);$$=strdup("undefined");}}
|
||||
|
||||
| assignable {printf("assignable expression\n");$$=$1;}
|
||||
| assignable {printf("assignable expression. current type is %s\n",$1);$$=$1;}
|
||||
|
||||
| L_PAREN expression R_PAREN {printf("paren expression\n");$$=$2;}
|
||||
| L_PAREN expression R_PAREN {printf("paren expression. current type is %s\n",$2);$$=$2;}
|
||||
|
||||
| memOp assignable {$$ = strdup("address");}
|
||||
;
|
||||
|
Reference in New Issue
Block a user