diff options
| author | Pierre-Marie Pédrot | 2018-07-26 14:27:10 +0200 |
|---|---|---|
| committer | Pierre-Marie Pédrot | 2018-07-26 14:27:10 +0200 |
| commit | 85d5f45d7a5374646a31f8829965bbfed0a95070 (patch) | |
| tree | d2dfb36735ed6591bd19bd446e621b79612efb52 /interp | |
| parent | 09c76adaff7adaada1c49479dfa9a4d0a4b416af (diff) | |
| parent | e32f18b2a98524611cf89a9c9d3f42b57ebf57eb (diff) | |
Merge PR #8100: Use just one object declaration for all global universe additions
Diffstat (limited to 'interp')
| -rw-r--r-- | interp/declare.ml | 28 |
1 files changed, 5 insertions, 23 deletions
diff --git a/interp/declare.ml b/interp/declare.ml index 0222aeb283..532339c03c 100644 --- a/interp/declare.ml +++ b/interp/declare.ml @@ -597,27 +597,8 @@ let do_universe poly l = ignore(Lib.add_leaf id (input_universe (src, lev)))) l -type constraint_decl = polymorphic * Univ.Constraint.t - -let cache_constraints (na, (p, c)) = - let ctx = - Univ.ContextSet.add_constraints c - Univ.ContextSet.empty (* No declared universes here, just constraints *) - in cache_universe_context (p,ctx) - -let discharge_constraints (_, (p, c as a)) = - if p then None else Some a - -let input_constraints : constraint_decl -> Libobject.obj = - let open Libobject in - declare_object - { (default_object "Global universe constraints") with - cache_function = cache_constraints; - load_function = (fun _ -> cache_constraints); - discharge_function = discharge_constraints; - classify_function = (fun a -> Keep a) } - let do_constraint poly l = + let open Univ in let u_of_id x = let level = Pretyping.interp_known_glob_level (Evd.from_env (Global.env ())) x in UnivNames.is_polymorphic level, level @@ -639,7 +620,8 @@ let do_constraint poly l = let constraints = List.fold_left (fun acc (l, d, r) -> let p, lu = u_of_id l and p', ru = u_of_id r in check_poly p p'; - Univ.Constraint.add (lu, d, ru) acc) - Univ.Constraint.empty l + Constraint.add (lu, d, ru) acc) + Constraint.empty l in - Lib.add_anonymous_leaf (input_constraints (poly, constraints)) + let uctx = ContextSet.add_constraints constraints ContextSet.empty in + declare_universe_context poly uctx |
