aboutsummaryrefslogtreecommitdiff
path: root/src/boot
diff options
context:
space:
mode:
Diffstat (limited to 'src/boot')
-rw-r--r--src/boot/me/resolve.ml4
-rw-r--r--src/boot/me/semant.ml12
2 files changed, 10 insertions, 6 deletions
diff --git a/src/boot/me/resolve.ml b/src/boot/me/resolve.ml
index be76bd30..fa5dcc06 100644
--- a/src/boot/me/resolve.ml
+++ b/src/boot/me/resolve.ml
@@ -768,12 +768,12 @@ let pattern_resolving_visitor
end
in
- let resolve_arm { node = arm; id = _ } =
+ let resolve_arm { node = arm; id = id } =
match fst arm with
Ast.PAT_tag (lval, pats) ->
let lval_nm = lval_to_name lval in
let lval_id = lval_base_id lval in
- let tag_ctor_id = (lval_item cx lval).id in
+ let tag_ctor_id = (lval_item ~node_id:id cx lval).id in
if defn_id_is_item cx tag_ctor_id
(* FIXME (issue #76): we should actually check here that the
diff --git a/src/boot/me/semant.ml b/src/boot/me/semant.ml
index e77f9754..1eb88ab1 100644
--- a/src/boot/me/semant.ml
+++ b/src/boot/me/semant.ml
@@ -1406,7 +1406,7 @@ let exports_permit (view:Ast.mod_view) (ident:Ast.ident) : bool =
;;
(* NB: this will fail if lval is not an item. *)
-let rec lval_item (cx:ctxt) (lval:Ast.lval) : Ast.mod_item =
+let rec lval_item ?node_id:node_id (cx:ctxt) (lval:Ast.lval) : Ast.mod_item =
match lval with
Ast.LVAL_base _ ->
let defn_id = lval_base_defn_id cx lval in
@@ -1429,9 +1429,13 @@ let rec lval_item (cx:ctxt) (lval:Ast.lval) : Ast.mod_item =
in
match htab_search items i with
| Some sub when exports_permit view i ->
- assert
- ((Array.length sub.node.Ast.decl_params) =
- (Array.length args));
+ if Array.length sub.node.Ast.decl_params !=
+ (Array.length args) then
+ err node_id
+ "%a has %d type-params but %d given"
+ Ast.sprintf_mod_item ("", sub)
+ (Array.length sub.node.Ast.decl_params)
+ (Array.length args);
check_concrete base_item.node.Ast.decl_params sub
| _ -> err (Some (lval_base_id lval))
"unknown module item '%s'" i