type conflict

This commit is contained in:
Mylloon 2023-10-17 17:29:40 +02:00
parent 3dc4a1068c
commit 0e81edc636
Signed by: Anri
GPG key ID: A82D63DFF8D1317F

View file

@ -6,9 +6,9 @@
%} %}
/* Opérateurs à ajouter au fur et a mesure (pour réduire les warnings temporairement) : /* Opérateurs à ajouter au fur et a mesure (pour réduire les warnings temporairement) :
* BINOP DO ELSE FOR FROM IF INFERIOR MATCH PIPE REF SUPERIOR THEN TO UNTIL WHILE */ * BINOP DO ELSE FOR FROM IF MATCH PIPE REF THEN TO UNTIL WHILE */
%token EOF LET TYPE WILDCARD STAR ARROW DPOINT EXTERN FUN COMMA AND EQUAL LPAREN %token EOF LET TYPE WILDCARD STAR ARROW DPOINT EXTERN FUN COMMA AND EQUAL LPAREN
%token RPAREN LBRACK RBRACK LBRACE RBRACE %token RPAREN LBRACK RBRACK LBRACE RBRACE INFERIOR SUPERIOR
%token<Mint.t> INT %token<Mint.t> INT
%token<string> ID TID CID %token<string> ID TID CID
@ -84,25 +84,42 @@ pattern:
} }
/* Ici on a un conflit entre :
* separated_nonempty_list(STAR,located(ty)) -> ty STAR separated_nonempty_list(STAR,located(ty))
* [ ty ] -> ty * [ ty ]
* ET
* ty -> ty STAR separated_nonempty_list(STAR,located(ty))
* ty -> ty * [ ty ]
*
* En gros il sait pas si il doit interpréter le premier type en tant que type
* ou en tant que list de type de 1 élément */
ty: ty:
/* Temporaire None - compile pas */ /* Application d'un constructeur de type */
/* | tc=type_constructor { | tc=type_constructor l=list_ty {
TyCon(tc, None) TyCon(tc, l)
} */ }
/* Fonctions */
/* Todo version avec l'optionnel */
| ty1=located(ty) ARROW ty2=located(ty) { | ty1=located(ty) ARROW ty2=located(ty) {
TyArrow(ty1, ty2) TyArrow(ty1, ty2)
} }
| ty1=located(ty) STAR ty2=located(ty) { /* N-uplets (N > 1) */
TyTuple([ty1; ty2]) | th=located(ty) STAR tt=separated_nonempty_list(STAR, located(ty)) {
TyTuple(th :: tt)
} }
| ty1=located(ty) STAR ty2=located(ty) STAR liste_ty=separated_list(STAR, located(ty)) { /* Variables de type */
TyTuple(ty1::ty2::liste_ty) | type_var=type_variable {
}
| LPAREN type_var=type_variable RPAREN {
TyVar type_var TyVar type_var
} }
/* Type entre parenthèses */
| LPAREN ty1=ty RPAREN {
ty1
}
/* Auxilliaire pour TyCon dans ty */
list_ty:
| INFERIOR tl=separated_list(COMMA, located(ty)) SUPERIOR {
tl
}
type_scheme: type_scheme: