From 2e3901329ab00a68f73e0e10b330a7cd46948d80 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Pierre-Marie=20P=C3=A9drot?= Date: Wed, 24 Jan 2024 08:58:08 +0100 Subject: [PATCH] Merge pull request #562 from rlepigre/br/fix-18281 Adapt to coq/coq#18327 (projection opacity) --- src/coq_elpi_builtins.ml | 21 +++++++++++++++------ 1 file changed, 15 insertions(+), 6 deletions(-) diff --git a/src/coq_elpi_builtins.ml b/src/coq_elpi_builtins.ml index adf541d70..fc4bf60c6 100644 --- a/src/coq_elpi_builtins.ml +++ b/src/coq_elpi_builtins.ml @@ -2816,8 +2816,11 @@ Supported attributes:|} ^ hint_locality_doc)))), let locality = hint_locality options in let transparent = not opaque in let r = match c with - | Variable v -> Tacred.EvalVarRef v - | Constant c -> Tacred.EvalConstRef c in + | Variable v -> Evaluable.EvalVarRef v + | Constant c -> + match Structures.PrimitiveProjections.find_opt c with + | None -> Evaluable.EvalConstRef c + | Some p -> Evaluable.EvalProjectionRef p in Hints.add_hints ~locality [db] Hints.(HintsTransparencyEntry(HintsReferences [r],transparent)); state, (), [] ))), @@ -3501,8 +3504,11 @@ coq.reduction.lazy.whd_all X Y :- (fun csts level ~depth:_ ctx _ -> grab_global_env "coq.strategy.set" (fun state -> let local = ctx.options.local = Some true in let csts = csts |> List.map (function - | Constant c -> Tacred.EvalConstRef c - | Variable v -> Tacred.EvalVarRef v) in + | Variable v -> Evaluable.EvalVarRef v + | Constant c -> + match Structures.PrimitiveProjections.find_opt c with + | None -> Evaluable.EvalConstRef c + | Some p -> Evaluable.EvalProjectionRef p) in Redexpr.set_strategy local [level, csts]; state, (), []))), DocAbove); @@ -3515,8 +3521,11 @@ coq.reduction.lazy.whd_all X Y :- let env = get_global_env state in let oracle = Environ.oracle env in let k = match c with - | Constant c -> Names.ConstKey c - | Variable v -> Names.VarKey v in + | Variable v -> Evaluable.EvalVarRef v + | Constant c -> + match Structures.PrimitiveProjections.find_opt c with + | None -> Evaluable.EvalConstRef c + | Some p -> Evaluable.EvalProjectionRef p in !: (Conv_oracle.get_strategy oracle k))), DocAbove);