Does not work

This commit is contained in:
Your Name 2019-03-05 20:41:58 +01:00
parent 9b9760f052
commit cbf565d4c0
2 changed files with 5 additions and 16 deletions

16
AST.mli
View File

@ -161,8 +161,7 @@ type ('a, 'type_expr_typecheck) gadt_if =
sufficient. sufficient.
*) *)
type 'x x_sig = 'x type 'x x_sig = 'x
constraint 'x = < annot: 'type_annotation; constraint 'x = 'type_annotation * 'type_expr_typecheck
type_expr_typecheck: 'bool1 >
type 'x ast = { type 'x ast = {
types : 'x type_decl reg list; types : 'x type_decl reg list;
@ -221,8 +220,7 @@ and 'x type_expr =
| Function of (('x type_expr list) * 'x type_expr, 'type_expr_typecheck) gadt_if | Function of (('x type_expr list) * 'x type_expr, 'type_expr_typecheck) gadt_if
| Mutable of ('x type_expr, 'type_expr_typecheck) gadt_if | Mutable of ('x type_expr, 'type_expr_typecheck) gadt_if
| Unit of (unit, 'type_expr_typecheck) gadt_if | Unit of (unit, 'type_expr_typecheck) gadt_if
constraint 'x = < type_expr_typecheck: 'type_expr_typecheck; constraint 'x = ('type_annotation * 'type_expr_typecheck)
.. >
constraint 'x = 'x x_sig constraint 'x = 'x x_sig
and 'x cartesian = ('x type_expr, times) nsepseq reg and 'x cartesian = ('x type_expr, times) nsepseq reg
@ -505,15 +503,9 @@ constraint 'x = 'x x_sig
(* Variations on the AST *) (* Variations on the AST *)
type parse_phase = < type parse_phase = (unit * tfalse)
annot: unit;
type_expr_typecheck: tfalse;
>
type typecheck_phase = < type typecheck_phase = (parse_phase type_expr * ttrue)
annot: typecheck_phase type_expr;
type_expr_typecheck: ttrue;
>
type t = parse_phase ast type t = parse_phase ast

View File

@ -3,10 +3,7 @@ module SMap = Map.Make(String)
open AST open AST
type i = parse_phase type i = parse_phase
type typecheck_phase = < type typecheck_phase = (parse_phase type_expr * tfalse)
annot: typecheck_phase type_expr;
type_expr_typecheck: tfalse;
>
type o = typecheck_phase type o = typecheck_phase
type te = o type_expr list SMap.t (* Type environment *) type te = o type_expr list SMap.t (* Type environment *)