diff options
| author | Maxime Dénès | 2018-11-23 16:08:41 +0100 |
|---|---|---|
| committer | Maxime Dénès | 2018-11-23 16:08:41 +0100 |
| commit | 12e6ce44d52695012a4219edb9d5522c86b407b8 (patch) | |
| tree | e7b877495a44fd5614a38b9773168d3b7e8d7693 /kernel | |
| parent | 371efb58fd9b528743a79b07998a5287fbc385d2 (diff) | |
| parent | 798e84b3313bd1e4b0f4937f31d4c570d2fa737f (diff) | |
Merge PR #8995: Don't redeclare constraints of fields in Include
Diffstat (limited to 'kernel')
| -rw-r--r-- | kernel/safe_typing.ml | 18 |
1 files changed, 14 insertions, 4 deletions
diff --git a/kernel/safe_typing.ml b/kernel/safe_typing.ml index 2464df799e..83d890b628 100644 --- a/kernel/safe_typing.ml +++ b/kernel/safe_typing.ml @@ -498,7 +498,7 @@ type generic_name = | M (** name already known, cf the mod_mp field *) | MT (** name already known, cf the mod_mp field *) -let add_field ((l,sfb) as field) gn senv = +let add_field ?(is_include=false) ((l,sfb) as field) gn senv = let mlabs,olabs = match sfb with | SFBmind mib -> let l = labels_of_mib mib in @@ -508,8 +508,18 @@ let add_field ((l,sfb) as field) gn senv = | SFBmodule _ | SFBmodtype _ -> check_modlabel l senv; (Label.Set.singleton l, Label.Set.empty) in - let cst = constraints_of_sfb senv.env sfb in - let senv = add_constraints_list cst senv in + let senv = + if is_include then + (* Universes and constraints were added when the included module + was defined eg in [Include F X.] (one of the trickier + versions of Include) the constraints on the fields are + exactly those of the fields of F which was defined + separately. *) + senv + else + let cst = constraints_of_sfb senv.env sfb in + add_constraints_list cst senv + in let env' = match sfb, gn with | SFBconst cb, C con -> Environ.add_constant con cb senv.env | SFBmind mib, I mind -> Environ.add_mind mind mib senv.env @@ -1049,7 +1059,7 @@ let add_include me is_module inl senv = | SFBmodule _ -> M | SFBmodtype _ -> MT in - add_field field new_name senv + add_field ~is_include:true field new_name senv in resolver, List.fold_left add senv str |
