type conflict
This commit is contained in:
parent
3dc4a1068c
commit
0e81edc636
1 changed files with 31 additions and 14 deletions
|
@ -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:
|
||||||
|
|
Reference in a new issue