From 08cf7690e635b81a6a83a930dccf92a3d5a2abd4 Mon Sep 17 00:00:00 2001 From: Hugo Herbelin Date: Wed, 27 Nov 2019 19:06:28 +0100 Subject: [PATCH 01/24] Using standard form for mkGApp in Coq (take argument list, not single argument). --- src/coq_elpi_glob_quotation.ml | 4 +--- 1 file changed, 1 insertion(+), 3 deletions(-) diff --git a/src/coq_elpi_glob_quotation.ml b/src/coq_elpi_glob_quotation.ml index f0bbf55cf..675271552 100644 --- a/src/coq_elpi_glob_quotation.ml +++ b/src/coq_elpi_glob_quotation.ml @@ -205,13 +205,11 @@ let rec gterm2lp depth state x = match (DAst.get x) (*.CAst.v*) with | Anonymous, Anonymous :: rest -> Anonymous,mkGHole, rest | Name x, [] -> Name x,DAst.make (GVar x), [] | Anonymous, [] -> Anonymous,mkGHole, [] in - let mkGapp hd args = - List.fold_left (Glob_ops.mkGApp ?loc:None) (DAst.make hd) args in let rec spine n names args ty = match Term.kind_of_type ty with | Term.SortType _ -> DAst.make (GLambda(as_name,Explicit, - mkGapp (GRef(GlobRef.IndRef ind,None)) (List.rev args), + Glob_ops.mkGApp (DAst.make (GRef(GlobRef.IndRef ind,None))) (List.rev args), Option.default mkGHole oty)) | Term.ProdType(name,src,tgt) when n = 0 -> let name, var, names = best_name name.Context.binder_name names in From 8666fda0396359d895fb8b778d7686a654585dc0 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Ga=C3=ABtan=20Gilbert?= Date: Wed, 30 Oct 2019 13:39:46 +0100 Subject: [PATCH 02/24] Adapt to coq/coq#10647 (inductive entries use boolean for cumulativity) --- src/coq_elpi_HOAS.ml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/coq_elpi_HOAS.ml b/src/coq_elpi_HOAS.ml index 5be8d673f..19851abea 100644 --- a/src/coq_elpi_HOAS.ml +++ b/src/coq_elpi_HOAS.ml @@ -1619,7 +1619,7 @@ let lp2inductive_entry ~depth coq_ctx constraints state t = mind_entry_inds = [oe]; mind_entry_universes = Monomorphic_entry (Evd.universe_context_set sigma); - mind_entry_variance = None; + mind_entry_cumulative = false; mind_entry_private = None; }, List.(concat (rev gls_rev)) in From 7a506255689de31a785bace13d7278e4c938d7b8 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Pierre-Marie=20P=C3=A9drot?= Date: Sun, 22 Dec 2019 18:19:08 +0100 Subject: [PATCH 03/24] Adapt to coq/coq#11293. --- src/coq_elpi_builtins.ml | 38 +++++++++++++++++++------------------- 1 file changed, 19 insertions(+), 19 deletions(-) diff --git a/src/coq_elpi_builtins.ml b/src/coq_elpi_builtins.ml index 4454fe99e..248e6e5b9 100644 --- a/src/coq_elpi_builtins.ml +++ b/src/coq_elpi_builtins.ml @@ -308,19 +308,19 @@ The name and the grafting specification can be left unspecified.|}; ] } |> CConv.(!<) -let class_ = let open Conv in let open API.AlgebraicData in let open Classops in declare { +let class_ = let open Conv in let open API.AlgebraicData in let open Coercionops in declare { ty = TyName "class"; doc = "Node of the coercion graph"; pp = (fun fmt _ -> Format.fprintf fmt ""); constructors = [ K("funclass","",N, B CL_FUN, - M (fun ~ok ~ko -> function Classops.CL_FUN -> ok | _ -> ko ())); + M (fun ~ok ~ko -> function Coercionops.CL_FUN -> ok | _ -> ko ())); K("sortclass","",N, B CL_SORT, M (fun ~ok ~ko -> function CL_SORT -> ok | _ -> ko ())); K("grefclass","",A(gref,N), - B Class.class_of_global, + B ComCoercion.class_of_global, M (fun ~ok ~ko -> function | CL_SECVAR v -> ok (GlobRef.VarRef v) | CL_CONST c -> ok (GlobRef.ConstRef c) @@ -331,11 +331,11 @@ let class_ = let open Conv in let open API.AlgebraicData in let open Classops in } |> CConv.(!<) let src_class_of_class = function - | (Classops.CL_FUN | Classops.CL_SORT) -> CErrors.anomaly Pp.(str "src_class_of_class on a non source coercion class") - | Classops.CL_SECVAR v -> GlobRef.VarRef v - | Classops.CL_CONST c -> GlobRef.ConstRef c - | Classops.CL_IND i -> GlobRef.IndRef i - | Classops.CL_PROJ p -> GlobRef.ConstRef (Projection.Repr.constant p) + | (Coercionops.CL_FUN | Coercionops.CL_SORT) -> CErrors.anomaly Pp.(str "src_class_of_class on a non source coercion class") + | Coercionops.CL_SECVAR v -> GlobRef.VarRef v + | Coercionops.CL_CONST c -> GlobRef.ConstRef c + | Coercionops.CL_IND i -> GlobRef.IndRef i + | Coercionops.CL_PROJ p -> GlobRef.ConstRef (Projection.Repr.constant p) let coercion = let open Conv in let open API.AlgebraicData in declare { ty = TyName "coercion"; @@ -1042,8 +1042,8 @@ It undestands qualified names, e.g. "Nat.t".|})), (fun (gr, _, source, target) global ~depth _ _ state -> let local = not (global = Given true) in let poly = false in - let source = Class.class_of_global source in - Class.try_add_new_coercion_with_target gr ~local ~poly ~source ~target; + let source = ComCoercion.class_of_global source in + ComCoercion.try_add_new_coercion_with_target gr ~local ~poly ~source ~target; let state = grab_global_state state in state, (), [])), DocAbove); @@ -1053,13 +1053,13 @@ It undestands qualified names, e.g. "Nat.t".|})), Easy ("reads all declared coercions")), (fun _ ~depth -> (* TODO: fix API in Coq *) - let pats = Classops.inheritance_graph () in + let pats = Coercionops.inheritance_graph () in let coercions = pats |> CList.map_filter (function | (source,target),[c] -> - Some(c.Classops.coe_value, - Given c.Classops.coe_param, - src_class_of_class @@ fst (Classops.class_info_from_index source), - fst (Classops.class_info_from_index target)) + Some(c.Coercionops.coe_value, + Given c.Coercionops.coe_param, + src_class_of_class @@ fst (Coercionops.class_info_from_index source), + fst (Coercionops.class_info_from_index target)) | _ -> None) in !: coercions)), DocAbove); @@ -1070,11 +1070,11 @@ It undestands qualified names, e.g. "Nat.t".|})), Out(list (pair gref int), "L", Easy ("reads all declared coercions")))), (fun source target _ ~depth -> - let source,_ = Classops.class_info source in - let target,_ = Classops.class_info target in - let path = Classops.lookup_path_between_class (source,target) in + let source,_ = Coercionops.class_info source in + let target,_ = Coercionops.class_info target in + let path = Coercionops.lookup_path_between_class (source,target) in let coercions = path |> List.map (fun c -> - c.Classops.coe_value, c.Classops.coe_param) in + c.Coercionops.coe_value, c.Coercionops.coe_param) in !: coercions)), DocAbove); From 44010a7b1fd605a32c614765c3da74ad3827e53b Mon Sep 17 00:00:00 2001 From: SimonBoulier Date: Mon, 6 Jan 2020 10:47:14 +0100 Subject: [PATCH 04/24] Adapt to coq/coq#11235 (Add syntax for non maximal implicit arguments) --- coq-builtin.elpi | 12 ++++++------ src/coq_elpi_builtins.ml | 38 +++++++++++++++++++------------------- 2 files changed, 25 insertions(+), 25 deletions(-) diff --git a/coq-builtin.elpi b/coq-builtin.elpi index 2e9001ac1..b1849a5eb 100644 --- a/coq-builtin.elpi +++ b/coq-builtin.elpi @@ -261,21 +261,21 @@ external pred coq.coercion.db-for i:class, i:class, % -- Coq's metadata --------------------------------------------------- % Implicit status of an argument -kind implicit_kind type. -type implicit implicit_kind. % regular implicit argument, eg Arguments foo [x] -type maximal implicit_kind. % maximally inserted implicit argument, eg Arguments foo {x} -type explicit implicit_kind. % explicit argument, eg Arguments foo x +kind binding_kind type. +type implicit binding_kind. % regular implicit argument, eg Arguments foo [x] +type maximal binding_kind. % maximally inserted implicit argument, eg Arguments foo {x} +type explicit binding_kind. % explicit argument, eg Arguments foo x % [coq.arguments.implicit GR Imps] reads the implicit arguments declarations % associated to a global reference. See also the [] and {} flags for the % Arguments command. -external pred coq.arguments.implicit i:gref, o:list (list implicit_kind). +external pred coq.arguments.implicit i:gref, o:list (list binding_kind). % [coq.arguments.set-implicit GR Imps Global] sets the implicit arguments % declarations associated to a global reference. Unspecified means explicit. % See also the [] and {} flags for the Arguments command. external pred coq.arguments.set-implicit i:gref, - i:list (list implicit_kind), + i:list (list binding_kind), i:@global?. % [coq.arguments.name GR Names] reads the Names of the arguments of a global diff --git a/src/coq_elpi_builtins.ml b/src/coq_elpi_builtins.ml index 248e6e5b9..be3915af8 100644 --- a/src/coq_elpi_builtins.ml +++ b/src/coq_elpi_builtins.ml @@ -348,30 +348,30 @@ let coercion = let open Conv in let open API.AlgebraicData in declare { ] } |> CConv.(!<) -let implicit_kind : Impargs.implicit_kind Conv.t = let open Conv in let open API.AlgebraicData in let open Impargs in declare { - ty = TyName "implicit_kind"; +let binding_kind : Glob_term.binding_kind Conv.t = let open Conv in let open API.AlgebraicData in let open Glob_term in declare { + ty = TyName "binding_kind"; doc = "Implicit status of an argument"; pp = (fun fmt -> function - | Implicit -> Format.fprintf fmt "implicit" - | NotImplicit -> Format.fprintf fmt "explicit" - | MaximallyImplicit -> Format.fprintf fmt "maximal"); + | NonMaxImplicit -> Format.fprintf fmt "implicit" + | Explicit -> Format.fprintf fmt "explicit" + | MaxImplicit -> Format.fprintf fmt "maximal"); constructors = [ K("implicit","regular implicit argument, eg Arguments foo [x]",N, - B Implicit, - M (fun ~ok ~ko -> function Implicit -> ok | _ -> ko ())); + B NonMaxImplicit, + M (fun ~ok ~ko -> function NonMaxImplicit -> ok | _ -> ko ())); K("maximal","maximally inserted implicit argument, eg Arguments foo {x}",N, - B MaximallyImplicit, - M (fun ~ok ~ko -> function MaximallyImplicit -> ok | _ -> ko ())); + B MaxImplicit, + M (fun ~ok ~ko -> function MaxImplicit -> ok | _ -> ko ())); K("explicit","explicit argument, eg Arguments foo x",N, - B NotImplicit, - M (fun ~ok ~ko -> function NotImplicit -> ok | _ -> ko ())); + B Explicit, + M (fun ~ok ~ko -> function Explicit -> ok | _ -> ko ())); ] } |> CConv.(!<) -let implicit_kind_of_status = function - | None -> Impargs.NotImplicit +let binding_kind_of_status = function + | None -> Glob_term.Explicit | Some (_,_,(maximal,_)) -> - if maximal then Impargs.MaximallyImplicit else Impargs.Implicit + if maximal then Glob_term.MaxImplicit else Glob_term.NonMaxImplicit let simplification_strategy = let open API.AlgebraicData in let open Reductionops.ReductionBehaviour in declare { @@ -1080,26 +1080,26 @@ It undestands qualified names, e.g. "Nat.t".|})), LPDoc "-- Coq's metadata ---------------------------------------------------"; - MLData implicit_kind; + MLData binding_kind; MLCode(Pred("coq.arguments.implicit", In(gref,"GR", - Out(list (list implicit_kind),"Imps", + Out(list (list binding_kind),"Imps", Easy "reads the implicit arguments declarations associated to a global reference. See also the [] and {} flags for the Arguments command.")), (fun gref _ ~depth -> - !: (List.map (fun (_,x) -> List.map implicit_kind_of_status x) + !: (List.map (fun (_,x) -> List.map binding_kind_of_status x) (Impargs.implicits_of_global gref)))), DocAbove); MLCode(Pred("coq.arguments.set-implicit", In(gref,"GR", - In(list (list (unspec implicit_kind)),"Imps", + In(list (list (unspec binding_kind)),"Imps", In(flag "@global?", "Global", Easy "sets the implicit arguments declarations associated to a global reference. Unspecified means explicit. See also the [] and {} flags for the Arguments command."))), (fun gref imps global ~depth -> let local = not (global = Given true) in let imps = imps |> List.(map (map (function - | Unspec -> Impargs.NotImplicit + | Unspec -> Glob_term.Explicit | Given x -> x))) in Impargs.set_implicits local gref imps)), DocAbove); From c059fa31bb0f676d0bc563442d719c5f98b9a121 Mon Sep 17 00:00:00 2001 From: Enrico Tassi Date: Thu, 23 Jan 2020 16:34:59 +0100 Subject: [PATCH 05/24] Revert "Merge pull request #104 from SimonBoulier/non_maximal_implicit" This reverts commit 97770ac7b4451f253068cb899b21bf268cede874, reversing changes made to f9e12000a37db98ca8e8e7c70aefd425f68620d9. --- coq-builtin.elpi | 12 ++++++------ src/coq_elpi_builtins.ml | 38 +++++++++++++++++++------------------- 2 files changed, 25 insertions(+), 25 deletions(-) diff --git a/coq-builtin.elpi b/coq-builtin.elpi index b1849a5eb..2e9001ac1 100644 --- a/coq-builtin.elpi +++ b/coq-builtin.elpi @@ -261,21 +261,21 @@ external pred coq.coercion.db-for i:class, i:class, % -- Coq's metadata --------------------------------------------------- % Implicit status of an argument -kind binding_kind type. -type implicit binding_kind. % regular implicit argument, eg Arguments foo [x] -type maximal binding_kind. % maximally inserted implicit argument, eg Arguments foo {x} -type explicit binding_kind. % explicit argument, eg Arguments foo x +kind implicit_kind type. +type implicit implicit_kind. % regular implicit argument, eg Arguments foo [x] +type maximal implicit_kind. % maximally inserted implicit argument, eg Arguments foo {x} +type explicit implicit_kind. % explicit argument, eg Arguments foo x % [coq.arguments.implicit GR Imps] reads the implicit arguments declarations % associated to a global reference. See also the [] and {} flags for the % Arguments command. -external pred coq.arguments.implicit i:gref, o:list (list binding_kind). +external pred coq.arguments.implicit i:gref, o:list (list implicit_kind). % [coq.arguments.set-implicit GR Imps Global] sets the implicit arguments % declarations associated to a global reference. Unspecified means explicit. % See also the [] and {} flags for the Arguments command. external pred coq.arguments.set-implicit i:gref, - i:list (list binding_kind), + i:list (list implicit_kind), i:@global?. % [coq.arguments.name GR Names] reads the Names of the arguments of a global diff --git a/src/coq_elpi_builtins.ml b/src/coq_elpi_builtins.ml index be3915af8..248e6e5b9 100644 --- a/src/coq_elpi_builtins.ml +++ b/src/coq_elpi_builtins.ml @@ -348,30 +348,30 @@ let coercion = let open Conv in let open API.AlgebraicData in declare { ] } |> CConv.(!<) -let binding_kind : Glob_term.binding_kind Conv.t = let open Conv in let open API.AlgebraicData in let open Glob_term in declare { - ty = TyName "binding_kind"; +let implicit_kind : Impargs.implicit_kind Conv.t = let open Conv in let open API.AlgebraicData in let open Impargs in declare { + ty = TyName "implicit_kind"; doc = "Implicit status of an argument"; pp = (fun fmt -> function - | NonMaxImplicit -> Format.fprintf fmt "implicit" - | Explicit -> Format.fprintf fmt "explicit" - | MaxImplicit -> Format.fprintf fmt "maximal"); + | Implicit -> Format.fprintf fmt "implicit" + | NotImplicit -> Format.fprintf fmt "explicit" + | MaximallyImplicit -> Format.fprintf fmt "maximal"); constructors = [ K("implicit","regular implicit argument, eg Arguments foo [x]",N, - B NonMaxImplicit, - M (fun ~ok ~ko -> function NonMaxImplicit -> ok | _ -> ko ())); + B Implicit, + M (fun ~ok ~ko -> function Implicit -> ok | _ -> ko ())); K("maximal","maximally inserted implicit argument, eg Arguments foo {x}",N, - B MaxImplicit, - M (fun ~ok ~ko -> function MaxImplicit -> ok | _ -> ko ())); + B MaximallyImplicit, + M (fun ~ok ~ko -> function MaximallyImplicit -> ok | _ -> ko ())); K("explicit","explicit argument, eg Arguments foo x",N, - B Explicit, - M (fun ~ok ~ko -> function Explicit -> ok | _ -> ko ())); + B NotImplicit, + M (fun ~ok ~ko -> function NotImplicit -> ok | _ -> ko ())); ] } |> CConv.(!<) -let binding_kind_of_status = function - | None -> Glob_term.Explicit +let implicit_kind_of_status = function + | None -> Impargs.NotImplicit | Some (_,_,(maximal,_)) -> - if maximal then Glob_term.MaxImplicit else Glob_term.NonMaxImplicit + if maximal then Impargs.MaximallyImplicit else Impargs.Implicit let simplification_strategy = let open API.AlgebraicData in let open Reductionops.ReductionBehaviour in declare { @@ -1080,26 +1080,26 @@ It undestands qualified names, e.g. "Nat.t".|})), LPDoc "-- Coq's metadata ---------------------------------------------------"; - MLData binding_kind; + MLData implicit_kind; MLCode(Pred("coq.arguments.implicit", In(gref,"GR", - Out(list (list binding_kind),"Imps", + Out(list (list implicit_kind),"Imps", Easy "reads the implicit arguments declarations associated to a global reference. See also the [] and {} flags for the Arguments command.")), (fun gref _ ~depth -> - !: (List.map (fun (_,x) -> List.map binding_kind_of_status x) + !: (List.map (fun (_,x) -> List.map implicit_kind_of_status x) (Impargs.implicits_of_global gref)))), DocAbove); MLCode(Pred("coq.arguments.set-implicit", In(gref,"GR", - In(list (list (unspec binding_kind)),"Imps", + In(list (list (unspec implicit_kind)),"Imps", In(flag "@global?", "Global", Easy "sets the implicit arguments declarations associated to a global reference. Unspecified means explicit. See also the [] and {} flags for the Arguments command."))), (fun gref imps global ~depth -> let local = not (global = Given true) in let imps = imps |> List.(map (map (function - | Unspec -> Glob_term.Explicit + | Unspec -> Impargs.NotImplicit | Given x -> x))) in Impargs.set_implicits local gref imps)), DocAbove); From f4cdcf9ff3586e04aa34b12a8a6498e3fc5e20c6 Mon Sep 17 00:00:00 2001 From: SimonBoulier Date: Mon, 6 Jan 2020 10:47:14 +0100 Subject: [PATCH 06/24] Adapt to coq/coq#11235 (Add syntax for non maximal implicit arguments) --- coq-builtin.elpi | 12 ++++++------ src/coq_elpi_builtins.ml | 38 +++++++++++++++++++------------------- 2 files changed, 25 insertions(+), 25 deletions(-) diff --git a/coq-builtin.elpi b/coq-builtin.elpi index 2e9001ac1..b1849a5eb 100644 --- a/coq-builtin.elpi +++ b/coq-builtin.elpi @@ -261,21 +261,21 @@ external pred coq.coercion.db-for i:class, i:class, % -- Coq's metadata --------------------------------------------------- % Implicit status of an argument -kind implicit_kind type. -type implicit implicit_kind. % regular implicit argument, eg Arguments foo [x] -type maximal implicit_kind. % maximally inserted implicit argument, eg Arguments foo {x} -type explicit implicit_kind. % explicit argument, eg Arguments foo x +kind binding_kind type. +type implicit binding_kind. % regular implicit argument, eg Arguments foo [x] +type maximal binding_kind. % maximally inserted implicit argument, eg Arguments foo {x} +type explicit binding_kind. % explicit argument, eg Arguments foo x % [coq.arguments.implicit GR Imps] reads the implicit arguments declarations % associated to a global reference. See also the [] and {} flags for the % Arguments command. -external pred coq.arguments.implicit i:gref, o:list (list implicit_kind). +external pred coq.arguments.implicit i:gref, o:list (list binding_kind). % [coq.arguments.set-implicit GR Imps Global] sets the implicit arguments % declarations associated to a global reference. Unspecified means explicit. % See also the [] and {} flags for the Arguments command. external pred coq.arguments.set-implicit i:gref, - i:list (list implicit_kind), + i:list (list binding_kind), i:@global?. % [coq.arguments.name GR Names] reads the Names of the arguments of a global diff --git a/src/coq_elpi_builtins.ml b/src/coq_elpi_builtins.ml index 248e6e5b9..be3915af8 100644 --- a/src/coq_elpi_builtins.ml +++ b/src/coq_elpi_builtins.ml @@ -348,30 +348,30 @@ let coercion = let open Conv in let open API.AlgebraicData in declare { ] } |> CConv.(!<) -let implicit_kind : Impargs.implicit_kind Conv.t = let open Conv in let open API.AlgebraicData in let open Impargs in declare { - ty = TyName "implicit_kind"; +let binding_kind : Glob_term.binding_kind Conv.t = let open Conv in let open API.AlgebraicData in let open Glob_term in declare { + ty = TyName "binding_kind"; doc = "Implicit status of an argument"; pp = (fun fmt -> function - | Implicit -> Format.fprintf fmt "implicit" - | NotImplicit -> Format.fprintf fmt "explicit" - | MaximallyImplicit -> Format.fprintf fmt "maximal"); + | NonMaxImplicit -> Format.fprintf fmt "implicit" + | Explicit -> Format.fprintf fmt "explicit" + | MaxImplicit -> Format.fprintf fmt "maximal"); constructors = [ K("implicit","regular implicit argument, eg Arguments foo [x]",N, - B Implicit, - M (fun ~ok ~ko -> function Implicit -> ok | _ -> ko ())); + B NonMaxImplicit, + M (fun ~ok ~ko -> function NonMaxImplicit -> ok | _ -> ko ())); K("maximal","maximally inserted implicit argument, eg Arguments foo {x}",N, - B MaximallyImplicit, - M (fun ~ok ~ko -> function MaximallyImplicit -> ok | _ -> ko ())); + B MaxImplicit, + M (fun ~ok ~ko -> function MaxImplicit -> ok | _ -> ko ())); K("explicit","explicit argument, eg Arguments foo x",N, - B NotImplicit, - M (fun ~ok ~ko -> function NotImplicit -> ok | _ -> ko ())); + B Explicit, + M (fun ~ok ~ko -> function Explicit -> ok | _ -> ko ())); ] } |> CConv.(!<) -let implicit_kind_of_status = function - | None -> Impargs.NotImplicit +let binding_kind_of_status = function + | None -> Glob_term.Explicit | Some (_,_,(maximal,_)) -> - if maximal then Impargs.MaximallyImplicit else Impargs.Implicit + if maximal then Glob_term.MaxImplicit else Glob_term.NonMaxImplicit let simplification_strategy = let open API.AlgebraicData in let open Reductionops.ReductionBehaviour in declare { @@ -1080,26 +1080,26 @@ It undestands qualified names, e.g. "Nat.t".|})), LPDoc "-- Coq's metadata ---------------------------------------------------"; - MLData implicit_kind; + MLData binding_kind; MLCode(Pred("coq.arguments.implicit", In(gref,"GR", - Out(list (list implicit_kind),"Imps", + Out(list (list binding_kind),"Imps", Easy "reads the implicit arguments declarations associated to a global reference. See also the [] and {} flags for the Arguments command.")), (fun gref _ ~depth -> - !: (List.map (fun (_,x) -> List.map implicit_kind_of_status x) + !: (List.map (fun (_,x) -> List.map binding_kind_of_status x) (Impargs.implicits_of_global gref)))), DocAbove); MLCode(Pred("coq.arguments.set-implicit", In(gref,"GR", - In(list (list (unspec implicit_kind)),"Imps", + In(list (list (unspec binding_kind)),"Imps", In(flag "@global?", "Global", Easy "sets the implicit arguments declarations associated to a global reference. Unspecified means explicit. See also the [] and {} flags for the Arguments command."))), (fun gref imps global ~depth -> let local = not (global = Given true) in let imps = imps |> List.(map (map (function - | Unspec -> Impargs.NotImplicit + | Unspec -> Glob_term.Explicit | Given x -> x))) in Impargs.set_implicits local gref imps)), DocAbove); From 4d19e789382276ac0c25283167a598c38c55c4d6 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Pierre-Marie=20P=C3=A9drot?= Date: Fri, 17 Jan 2020 15:32:33 +0100 Subject: [PATCH 07/24] Fix w.r.t. coq/coq#11417. --- src/coq_elpi_glob_quotation.ml | 15 ++++++++------- 1 file changed, 8 insertions(+), 7 deletions(-) diff --git a/src/coq_elpi_glob_quotation.ml b/src/coq_elpi_glob_quotation.ml index 675271552..85bf90809 100644 --- a/src/coq_elpi_glob_quotation.ml +++ b/src/coq_elpi_glob_quotation.ml @@ -206,21 +206,22 @@ let rec gterm2lp depth state x = match (DAst.get x) (*.CAst.v*) with | Name x, [] -> Name x,DAst.make (GVar x), [] | Anonymous, [] -> Anonymous,mkGHole, [] in let rec spine n names args ty = - match Term.kind_of_type ty with - | Term.SortType _ -> + let open Constr in + match kind ty with + | Sort _ -> DAst.make (GLambda(as_name,Explicit, Glob_ops.mkGApp (DAst.make (GRef(GlobRef.IndRef ind,None))) (List.rev args), Option.default mkGHole oty)) - | Term.ProdType(name,src,tgt) when n = 0 -> + | Prod (name, src, tgt) when n = 0 -> let name, var, names = best_name name.Context.binder_name names in DAst.make (GLambda(name,Explicit, mkGHole,spine (n-1) (safe_tail names) (var :: args) tgt)) - | Term.LetInType(name,v,_,b) -> + | LetIn (name, v, _, b) -> spine n names args (Vars.subst1 v b) - | Term.CastType(t,_) -> spine n names args t - | Term.ProdType(_,_,t) -> + | Cast (t, _, _) -> spine n names args t + | Prod (_, _, t) -> spine (n-1) (safe_tail names) (mkGHole :: args) t - | Term.AtomicType _ -> assert false in + | _ -> assert false in gterm2lp depth state (spine mind_nparams args_name [] ty) in let bs = List.map (fun {CAst.v=(fv,pat,bo)} -> From ee23b610addf4d85856f0687e88e12e34003707d Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Ga=C3=ABtan=20Gilbert?= Date: Tue, 11 Feb 2020 09:44:39 +0100 Subject: [PATCH 08/24] Adapt to coq/coq#11557 (Inductive.type_of_inductive doesn't take an env) --- src/coq_elpi_builtins.ml | 2 +- src/coq_elpi_glob_quotation.ml | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/src/coq_elpi_builtins.ml b/src/coq_elpi_builtins.ml index be3915af8..ead2eb0b1 100644 --- a/src/coq_elpi_builtins.ml +++ b/src/coq_elpi_builtins.ml @@ -551,7 +551,7 @@ It undestands qualified names, e.g. "Nat.t".|})), let lno = mind.mind_nparams in let luno = mind.mind_nparams_rec in let arity = if_keep arity (fun () -> - Inductive.type_of_inductive env (ind,Univ.Instance.empty) + Inductive.type_of_inductive (ind,Univ.Instance.empty) |> EConstr.of_constr) in let knames = if_keep knames (fun () -> CList.(init Declarations.(indbo.mind_nb_constant + indbo.mind_nb_args) diff --git a/src/coq_elpi_glob_quotation.ml b/src/coq_elpi_glob_quotation.ml index 85bf90809..207368943 100644 --- a/src/coq_elpi_glob_quotation.ml +++ b/src/coq_elpi_glob_quotation.ml @@ -197,7 +197,7 @@ let rec gterm2lp depth state x = match (DAst.get x) (*.CAst.v*) with * the term can be read back (mkCases needs the ind) *) (* TODO: add whd reduction in spine *) let ty = - Inductive.type_of_inductive env (indspecif,Univ.Instance.empty) in + Inductive.type_of_inductive (indspecif,Univ.Instance.empty) in let safe_tail = function [] -> [] | _ :: x -> x in let best_name n l = match n, l with | _, (Name x) :: rest -> Name x,DAst.make (GVar x), rest From 0e370e174fe00e522defba9dc958227533569a3d Mon Sep 17 00:00:00 2001 From: Enrico Tassi Date: Mon, 2 Mar 2020 15:02:57 +0100 Subject: [PATCH 09/24] fix ci --- .travis.yml | 4 ++-- coq-elpi.opam | 2 +- 2 files changed, 3 insertions(+), 3 deletions(-) diff --git a/.travis.yml b/.travis.yml index d8b85c789..478b8c56d 100644 --- a/.travis.yml +++ b/.travis.yml @@ -9,8 +9,8 @@ env: - NJOBS="2" - CONTRIB_NAME="coq-elpi" matrix: - - COQ="coqorg/coq:8.11" ELPI="elpi.1.10.2" CMD="make && make install" - - COQ="coqorg/coq:8.11" ELPI="elpi.1.10.2" CMD="opam pin add coq-elpi . -y -v" + - COQ="coqorg/coq:dev" ELPI="elpi.1.10.2" CMD="make && make install" + - COQ="coqorg/coq:dev" ELPI="elpi.1.10.2" CMD="opam pin add coq-elpi . -y -v" banches: only: diff --git a/coq-elpi.opam b/coq-elpi.opam index 9aae3f054..6c5c85fc2 100644 --- a/coq-elpi.opam +++ b/coq-elpi.opam @@ -12,7 +12,7 @@ build: [ make "COQBIN=%{bin}%/" "ELPIDIR=%{prefix}%/lib/elpi" ] install: [ make "install" "COQBIN=%{bin}%/" "ELPIDIR=%{prefix}%/lib/elpi" ] depends: [ "elpi" {>= "1.10.2" & < "1.11.0~"} - "coq" {>= "8.11" & < "8.12~" } + "coq" {= "dev" } ] synopsis: "Elpi extension language for Coq" description: """ From 607397432d328c42541e5f4998cb96f9bffa7f30 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Pierre-Marie=20P=C3=A9drot?= Date: Sun, 8 Mar 2020 15:37:24 +0100 Subject: [PATCH 10/24] Fix w.r.t. coq/coq#11764. --- src/coq_elpi_HOAS.ml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/coq_elpi_HOAS.ml b/src/coq_elpi_HOAS.ml index 919d21587..de4a6620c 100644 --- a/src/coq_elpi_HOAS.ml +++ b/src/coq_elpi_HOAS.ml @@ -1703,11 +1703,11 @@ let lp2inductive_entry ~depth coq_ctx constraints state t = let oe = { mind_entry_typename = itname; mind_entry_arity = arity; - mind_entry_template = false; mind_entry_consnames = knames; mind_entry_lc = ktypes } in state, { mind_entry_record = if finiteness = Declarations.BiFinite then Some None else None; + mind_entry_template = false; mind_entry_finite = finiteness; mind_entry_params = params; mind_entry_inds = [oe]; From ae2511e575634445e0c63a7a70b224ace1e14a75 Mon Sep 17 00:00:00 2001 From: Emilio Jesus Gallego Arias Date: Sun, 8 Mar 2020 05:50:37 -0400 Subject: [PATCH 11/24] [coq] Adapt to coq/coq#11731 --- src/coq_elpi_builtins.ml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/coq_elpi_builtins.ml b/src/coq_elpi_builtins.ml index c3b8f8117..159bcae6e 100644 --- a/src/coq_elpi_builtins.ml +++ b/src/coq_elpi_builtins.ml @@ -908,7 +908,7 @@ It undestands qualified names, e.g. "Nat.t".|})), let gr = DeclareDef.declare_definition ~name:(Id.of_string id) ~scope ~kind - UnivNames.empty_binders ce [] in + ~ubind:UnivNames.empty_binders ~impargs:[] ce in state, !: (global_constant_of_globref gr), []))), DocAbove); From b1044ce2e04cc66af85c151dece3375102b696f0 Mon Sep 17 00:00:00 2001 From: Emilio Jesus Gallego Arias Date: Mon, 23 Mar 2020 03:42:12 -0400 Subject: [PATCH 12/24] [coq] Overlay for coq/coq#11818 --- src/coq_elpi_builtins.ml | 40 ++++++++++++++-------------------------- 1 file changed, 14 insertions(+), 26 deletions(-) diff --git a/src/coq_elpi_builtins.ml b/src/coq_elpi_builtins.ml index 159bcae6e..d20dc1d53 100644 --- a/src/coq_elpi_builtins.ml +++ b/src/coq_elpi_builtins.ml @@ -850,12 +850,12 @@ It undestands qualified names, e.g. "Nat.t".|})), "Definition x := t); Bo can be left unspecified and in that case "^ "an axiom is added (or a section variable, if a section is open). "^ "Omitting the body and the type is an error."))))))), - (fun id bo ty opaque local _ ~depth env _ -> on_global_state "coq.env.add-const" (fun state -> + (fun id body types opaque local _ ~depth env _ -> on_global_state "coq.env.add-const" (fun state -> let local = local = Given true in let sigma = get_sigma state in - match bo with + match body with | Unspec -> (* axiom *) - begin match ty with + begin match types with | Unspec -> err Pp.(str "coq.env.add-const: both Type and Body are unspecified") | Given ty -> @@ -883,32 +883,20 @@ It undestands qualified names, e.g. "Nat.t".|})), in state, !: (global_constant_of_globref gr), [] end - | Given bo -> - let ty = - match ty with + | Given body -> + let types = + match types with | Unspec -> None | Given ty -> Some ty in - let bo, ty = EConstr.(to_constr sigma bo, Option.map (to_constr sigma) ty) in - let ce = - let sigma = Evd.minimize_universes sigma in - let fold uvars c = - Univ.LSet.union uvars - (EConstr.universes_of_constr sigma (EConstr.of_constr c)) - in - let univ_vars = - List.fold_left fold Univ.LSet.empty (Option.List.cons ty [bo]) in - let sigma = Evd.restrict_universe_context sigma univ_vars in - (* Check we conform to declared universes *) - let uctx = - Evd.check_univ_decl ~poly:false sigma UState.default_univ_decl in - Declare.definition_entry - ~opaque:(opaque = Given true) ?types:ty ~univs:uctx bo in - let scope = if local then DeclareDef.Discharge else DeclareDef.Global Declare.ImportDefaultBehavior in + let udecl = UState.default_univ_decl in let kind = Decls.(IsDefinition Definition) in - let gr = - DeclareDef.declare_definition - ~name:(Id.of_string id) ~scope ~kind - ~ubind:UnivNames.empty_binders ~impargs:[] ce in + let scope = if local + then DeclareDef.Discharge + else DeclareDef.Global Declare.ImportDefaultBehavior in + let gr = DeclareDef.declare_definition + ~name:(Id.of_string id) ~scope ~kind ~impargs:[] + ~poly:false ~udecl ~opaque:(opaque = Given true) ~types ~body sigma + in state, !: (global_constant_of_globref gr), []))), DocAbove); From 99352b892ffa33ce23abf0f8d412969fa6745e43 Mon Sep 17 00:00:00 2001 From: Enrico Tassi Date: Sun, 5 Apr 2020 16:33:17 +0200 Subject: [PATCH 13/24] remove dependency on ppx_deriving --- Makefile.coq.local | 4 ++-- src/coq_elpi_HOAS.ml | 10 ++++++---- src/coq_elpi_vernacular.ml | 9 +++++---- 3 files changed, 13 insertions(+), 10 deletions(-) diff --git a/Makefile.coq.local b/Makefile.coq.local index adc19004b..c6c25b571 100644 --- a/Makefile.coq.local +++ b/Makefile.coq.local @@ -1,4 +1,4 @@ -CAMLPKGS+= -package elpi,ppx_deriving.std +CAMLPKGS+= -package elpi CAMLFLAGS+= -bin-annot -g TESTS=$(wildcard theories/tests/*.v) @@ -31,7 +31,7 @@ theories/derive/bcongr.vo: ltac/injection.elpi @if [ -e $@ ]; then touch $@; fi merlin-hook:: - echo "PKG ppx_deriving.std camlp5" >> .merlin + echo "PKG camlp5" >> .merlin echo "S $(abspath $(ELPIDIR))" >> .merlin echo "B $(abspath $(ELPIDIR))" >> .merlin if [ "$(ELPIDIR)" != "elpi/findlib/elpi" ]; then\ diff --git a/src/coq_elpi_HOAS.ml b/src/coq_elpi_HOAS.ml index 919d21587..4b948c8cf 100644 --- a/src/coq_elpi_HOAS.ml +++ b/src/coq_elpi_HOAS.ml @@ -340,11 +340,13 @@ module CoqEngine_HOAS : sig end = struct type coq_engine = { - global_env : Environ.env [@printer (fun _ _ -> ())]; - sigma : Evd.evar_map [@printer (fun fmt m -> - Format.fprintf fmt "%s" Pp.(string_of_ppcmds (Termops.pr_evar_map None (Global.env()) m)))]; + global_env : Environ.env; + sigma : Evd.evar_map; } - [@@deriving show] + let pp_coq_engine fmt { sigma } = + Format.fprintf fmt "%s" Pp.(string_of_ppcmds (Termops.pr_evar_map None (Global.env()) sigma)) + +let show_coq_engine = Format.asprintf "%a" pp_coq_engine let empty_from_env_sigma global_env sigma = { diff --git a/src/coq_elpi_vernacular.ml b/src/coq_elpi_vernacular.ml index 59c28f405..d46a2f716 100644 --- a/src/coq_elpi_vernacular.ml +++ b/src/coq_elpi_vernacular.ml @@ -42,7 +42,8 @@ let parse_goal loc x = CErrors.user_err ~loc ~hdr:"elpi" (Pp.str msg) -type qualified_name = string list [@@deriving ord] +type qualified_name = string list +let compare_qualified_name = Pervasives.compare let pr_qualified_name = Pp.prlist_with_sep (fun () -> Pp.str".") Pp.str let show_qualified_name = String.concat "." let _pp_qualified_name fmt l = Format.fprintf fmt "%s" (String.concat "." l) @@ -245,14 +246,14 @@ type src = | Database of qualified_name and src_file = { fname : string; - fast : EC.compilation_unit [@compare fun _ _ -> 0 ] [@opaque] + fast : EC.compilation_unit } and src_string = { sloc : API.Ast.Loc.t; sdata : string; - sast : EC.compilation_unit [@compare fun _ _ -> 0] [@opaque] + sast : EC.compilation_unit } -[@@deriving ord] +let compare_src = Pervasives.compare module SrcSet = Set.Make(struct type t = src let compare = compare_src end) From 034ec95a55f6a8d9184c0813400e61d8edba043f Mon Sep 17 00:00:00 2001 From: Enrico Tassi Date: Sun, 5 Apr 2020 22:11:35 +0200 Subject: [PATCH 14/24] no need to limit trace pp to 30 boxes --- src/coq_elpi_vernacular.ml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/coq_elpi_vernacular.ml b/src/coq_elpi_vernacular.ml index d46a2f716..faf014284 100644 --- a/src/coq_elpi_vernacular.ml +++ b/src/coq_elpi_vernacular.ml @@ -625,7 +625,7 @@ let mk_trace_opts start stop preds = ; "-trace-only"; "run" ; "-trace-only"; "select" ; "-trace-only"; "assign" - ; "-trace-maxbox"; "30" + (* ; "-trace-tty-maxbox"; "30" *) ] @ List.(flatten (map (fun x -> ["-trace-only-pred"; x]) preds)) let trace start stop preds opts = From d9d7983dc3e5251a1fcf587994840d28d00fbbb6 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Pierre-Marie=20P=C3=A9drot?= Date: Wed, 25 Mar 2020 14:23:21 +0100 Subject: [PATCH 15/24] Fix w.r.t. coq/coq#11896. --- src/coq_elpi_HOAS.ml | 12 ++++++------ 1 file changed, 6 insertions(+), 6 deletions(-) diff --git a/src/coq_elpi_HOAS.ml b/src/coq_elpi_HOAS.ml index 5c6b9f740..4d80c35a6 100644 --- a/src/coq_elpi_HOAS.ml +++ b/src/coq_elpi_HOAS.ml @@ -582,9 +582,9 @@ let rec constr2lp coq_ctx ~calldepth ~depth state t = the depth at which it is found *) let state, elpi_uvk, _, gsl_t = in_elpi_evar ~calldepth k state in gls := gsl_t @ !gls; - let args = Array.sub args 0 (Array.length args - coq_ctx.section_len) in - let state, args = CArray.fold_left_map (aux ~depth) state args in - state, E.mkUnifVar elpi_uvk ~args:(CArray.rev_to_list args) state + let args = CList.firstn (List.length args - coq_ctx.section_len) args in + let state, args = CList.fold_left_map (aux ~depth) state args in + state, E.mkUnifVar elpi_uvk ~args:(List.rev args) state | C.Sort s -> state, in_elpi_sort (EC.ESorts.kind sigma s) | C.Cast (t,_,ty) -> let state, t = aux ~depth state t in @@ -1009,15 +1009,15 @@ and lp2constr ~calldepth syntactic_constraints coq_ctx ~depth state ?(on_ty=fals let nargs = List.length all_args in if nargs > arity then let args1, args2 = CList.chop (nargs - arity) all_args in - EC.mkApp(EC.mkEvar (ext_key,CArray.of_list args2), + EC.mkApp(EC.mkEvar (ext_key, args2), CArray.rev_of_list args1) else - EC.mkEvar (ext_key,CArray.of_list all_args) in + EC.mkEvar (ext_key, all_args) in if debug () then Feedback.msg_debug Pp.(str"lp2term: evar: args: " ++ let _, args = EC.destEvar (get_sigma state) ev in - prlist_with_sep spc (Printer.pr_econstr_env coq_ctx.env (get_sigma state)) (Array.to_list args) + prlist_with_sep spc (Printer.pr_econstr_env coq_ctx.env (get_sigma state)) args ); state, ev, gl1 From a02cdd81f406ddb94232e612ab8722f0dd686f77 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Ga=C3=ABtan=20Gilbert?= Date: Fri, 10 Apr 2020 10:04:35 +0200 Subject: [PATCH 16/24] Adapt to coq/coq#11820 (partial imports) --- src/coq_elpi_builtins.ml | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/coq_elpi_builtins.ml b/src/coq_elpi_builtins.ml index d20dc1d53..18b71e6db 100644 --- a/src/coq_elpi_builtins.ml +++ b/src/coq_elpi_builtins.ml @@ -1012,7 +1012,7 @@ It undestands qualified names, e.g. "Nat.t".|})), In(modpath, "ModPath", Full(unit_ctx, "is like the vernacular Import *E*")), (fun mp ~depth _ _ -> on_global_state "coq.env.import-module" (fun state -> - Declaremods.import_module ~export:false mp; + Declaremods.import_module ~export:false Libobject.Unfiltered mp; state, (), []))), DocAbove); @@ -1020,7 +1020,7 @@ It undestands qualified names, e.g. "Nat.t".|})), In(modpath, "ModPath", Full(unit_ctx, "is like the vernacular Export *E*")), (fun mp ~depth _ _ -> on_global_state "coq.env.export-module" (fun state -> - Declaremods.import_module ~export:true mp; + Declaremods.import_module ~export:true Libobject.Unfiltered mp; state, (), []))), DocAbove); From 24ff8f90f2ae5ef0cb7ebe2a56a5dde229ac4d76 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Ga=C3=ABtan=20Gilbert?= Date: Mon, 20 Apr 2020 13:17:55 +0200 Subject: [PATCH 17/24] Adapt to coq/coq#12107 (no mod_constraints field in module structures) --- src/coq_elpi_HOAS.ml | 1 - 1 file changed, 1 deletion(-) diff --git a/src/coq_elpi_HOAS.ml b/src/coq_elpi_HOAS.ml index 5c6b9f740..e0a7b891b 100644 --- a/src/coq_elpi_HOAS.ml +++ b/src/coq_elpi_HOAS.ml @@ -1858,7 +1858,6 @@ and in_elpi_module : 'a. depth:int -> API.Data.state -> 'a Declarations.generic_ mod_expr; (* Declarations.module_implementation *) mod_type; (* Declarations.module_signature *) mod_type_alg; (* Declarations.module_expression option *) - mod_constraints; (* Univ.ContextSet.t *) mod_delta; (* Mod_subst.delta_resolver *) mod_retroknowledge; (* Retroknowledge.action list *) } -> From 856f93829d61b0eba9f6ab1ab3b7a887a1e3356d Mon Sep 17 00:00:00 2001 From: Hugo Herbelin Date: Tue, 14 Apr 2020 22:20:50 +0200 Subject: [PATCH 18/24] Adapting to Coq PR #8808: aligning the expressiveness of syndefs on notations. --- src/coq_elpi_builtins.ml | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/coq_elpi_builtins.ml b/src/coq_elpi_builtins.ml index 7984d9fb2..d5c026755 100644 --- a/src/coq_elpi_builtins.ml +++ b/src/coq_elpi_builtins.ml @@ -1428,8 +1428,8 @@ Deprecation can be (pr "version" "note")|})))))))), { nenv with Notation_term.ninterp_var_type = Id.Map.add id Notation_term.NtnInternTypeAny nenv.Notation_term.ninterp_var_type }, - (id, (None,[])) :: vars - | _ -> nenv, (Names.Id.of_string_soft "_", (None,[])) :: vars in + (id, ((Constrexpr.InConstrEntrySomeLevel,(None,[])),Notation_term.NtnTypeConstr)) :: vars + | _ -> nenv, (Names.Id.of_string_soft "_", ((Constrexpr.InConstrEntrySomeLevel,(None,[])),Notation_term.NtnTypeConstr)) :: vars in let env = EConstr.push_rel (Context.Rel.Declaration.LocalAssum(name,ty)) env in aux vars nenv env (n-1) t | _ -> From 38f1053278fbee5f3e9d4d138febcdfd72a0020d Mon Sep 17 00:00:00 2001 From: Enrico Tassi Date: Mon, 18 May 2020 19:05:47 +0200 Subject: [PATCH 19/24] fix compilation on master --- coq-builtin.elpi | 12 ++++++------ src/coq_elpi_HOAS.ml | 35 +++++++++++++++++----------------- src/coq_elpi_HOAS.mli | 8 ++++---- src/coq_elpi_builtins.ml | 20 +++++++++---------- src/coq_elpi_glob_quotation.ml | 2 +- src/coq_elpi_goal_HOAS.ml | 2 +- src/coq_elpi_utils.ml | 18 ++++------------- src/coq_elpi_utils.mli | 4 +--- src/coq_elpi_vernacular.ml | 2 +- 9 files changed, 46 insertions(+), 57 deletions(-) diff --git a/coq-builtin.elpi b/coq-builtin.elpi index 09dd3a1d9..ef4f007ac 100644 --- a/coq-builtin.elpi +++ b/coq-builtin.elpi @@ -677,22 +677,22 @@ external pred coq.coercion.db-for i:class, i:class, % -- Coq's notational mechanisms ------------------------------------- % Implicit status of an argument -kind binding_kind type. -type implicit binding_kind. % regular implicit argument, eg Arguments foo [x] -type maximal binding_kind. % maximally inserted implicit argument, eg Arguments foo {x} -type explicit binding_kind. % explicit argument, eg Arguments foo x +kind implicit_kind type. +type implicit implicit_kind. % regular implicit argument, eg Arguments foo [x] +type maximal implicit_kind. % maximally inserted implicit argument, eg Arguments foo {x} +type explicit implicit_kind. % explicit argument, eg Arguments foo x % [coq.arguments.implicit GR Imps] reads the implicit arguments declarations % associated to a global reference. See also the [] and {} flags for the % Arguments command. -external pred coq.arguments.implicit i:gref, o:list (list binding_kind). +external pred coq.arguments.implicit i:gref, o:list (list implicit_kind). % [coq.arguments.set-implicit GR Imps Global] sets the implicit arguments % declarations associated to a global reference. % Unspecified means explicit. % See also the [] and {} flags for the Arguments command. external pred coq.arguments.set-implicit i:gref, - i:list (list binding_kind), + i:list (list implicit_kind), i:global?. % [coq.arguments.name GR Names] reads the Names of the arguments of a global diff --git a/src/coq_elpi_HOAS.ml b/src/coq_elpi_HOAS.ml index 6b303f0e3..f0e874584 100644 --- a/src/coq_elpi_HOAS.ml +++ b/src/coq_elpi_HOAS.ml @@ -1561,29 +1561,29 @@ let is_canonical_att = function in aux l -let implicit_kind : Impargs.implicit_kind API.Conversion.t = let open API.Conversion in let open API.AlgebraicData in let open Impargs in declare { +let implicit_kind : Glob_term.binding_kind API.Conversion.t = let open API.Conversion in let open API.AlgebraicData in let open Glob_term in declare { ty = TyName "implicit_kind"; doc = "Implicit status of an argument"; pp = (fun fmt -> function - | Implicit -> Format.fprintf fmt "implicit" - | NotImplicit -> Format.fprintf fmt "explicit" - | MaximallyImplicit -> Format.fprintf fmt "maximal"); + | NonMaxImplicit -> Format.fprintf fmt "implicit" + | Explicit -> Format.fprintf fmt "explicit" + | MaxImplicit -> Format.fprintf fmt "maximal"); constructors = [ K("implicit","regular implicit argument, eg Arguments foo [x]",N, - B Implicit, - M (fun ~ok ~ko -> function Implicit -> ok | _ -> ko ())); + B NonMaxImplicit, + M (fun ~ok ~ko -> function NonMaxImplicit -> ok | _ -> ko ())); K("maximal","maximally inserted implicit argument, eg Arguments foo {x}",N, - B MaximallyImplicit, - M (fun ~ok ~ko -> function MaximallyImplicit -> ok | _ -> ko ())); + B MaxImplicit, + M (fun ~ok ~ko -> function MaxImplicit -> ok | _ -> ko ())); K("explicit","explicit argument, eg Arguments foo x",N, - B NotImplicit, - M (fun ~ok ~ko -> function NotImplicit -> ok | _ -> ko ())); + B Explicit, + M (fun ~ok ~ko -> function Explicit -> ok | _ -> ko ())); ] } |> API.ContextualConversion.(!<) let in_coq_imp ~depth st x = match (unspec implicit_kind).API.Conversion.readback ~depth st x with - | st, Unspec, gl -> assert(gl = []); st, Impargs.NotImplicit + | st, Unspec, gl -> assert(gl = []); st, Glob_term.Explicit | st, Given x, gl -> assert(gl = []); st, x let in_elpi_imp ~depth st x = @@ -1592,7 +1592,7 @@ let in_elpi_imp ~depth st x = st, x let in_elpi_explicit ~depth state = - let _, x = in_elpi_imp ~depth state Impargs.NotImplicit in + let _, x = in_elpi_imp ~depth state Glob_term.Explicit in x let parameterc = E.Constants.declare_global_symbol "parameter" @@ -1671,7 +1671,7 @@ let readback_arity ~depth coq_ctx constraints state t = let state, imp = in_coq_imp ~depth state imp in let state, ty, gls = lp2constr coq_ctx ~depth state ty in let e = Context.Rel.Declaration.LocalAssum(name,ty) in - aux_lam e coq_ctx ~depth (e :: params) (manual_implicit_of_implicit_kind (Context.binder_name name) imp :: impls) state (gls :: extra) decl + aux_lam e coq_ctx ~depth (e :: params) (manual_implicit_of_binding_kind (Context.binder_name name) imp :: impls) state (gls :: extra) decl | E.App(c,ty,[]) when c == arityc -> let state, ty, gls = lp2constr coq_ctx ~depth state ty in state, params, impls, ty, List.flatten @@ gls :: extra @@ -1857,10 +1857,11 @@ let lp2inductive_entry ~depth coq_ctx constraints state t = mind_entry_typename = itname; mind_entry_arity = arity; mind_entry_consnames = knames; - mind_entry_lc = ktypes } in + mind_entry_lc = ktypes; + } in state, { - mind_entry_record = if finiteness = Declarations.BiFinite then Some None else None; mind_entry_template = false; + mind_entry_record = if finiteness = Declarations.BiFinite then Some None else None; mind_entry_finite = finiteness; mind_entry_params = params; mind_entry_inds = [oe]; @@ -1898,7 +1899,7 @@ let lp2inductive_entry ~depth coq_ctx constraints state t = let state, imp = in_coq_imp ~depth state imp in let state, ty, gls = lp2constr coq_ctx ~depth state ty in let e = Context.Rel.Declaration.LocalAssum(name,ty) in - aux_lam e coq_ctx ~depth (e :: params) (manual_implicit_of_implicit_kind (Context.binder_name name) imp :: impls) state (gls :: extra) decl + aux_lam e coq_ctx ~depth (e :: params) (manual_implicit_of_binding_kind (Context.binder_name name) imp :: impls) state (gls :: extra) decl | E.App(c,id,[fin;arity;ks]) when c == inductivec -> let name = in_coq_annot ~depth id in @@ -1998,7 +1999,7 @@ let inductive_decl2lp ~depth coq_ctx constraints state ((mind,ind),(i_impls,k_im let k_impls = List.map (drop_upto_nparams_from_ctx paramsno) k_impls in let arity = drop_nparams_from_term allparamsno - (Inductive.type_of_inductive (get_global_env state) ((mind,ind),Univ.Instance.empty)) in + (Inductive.type_of_inductive ((mind,ind),Univ.Instance.empty)) in let knames = CArray.map_to_list (fun x -> Name x) ind.Declarations.mind_consnames in let ktys = CArray.map_to_list (fun (ctx,x) -> let ctx = drop_nparams_from_ctx paramsno @@ List.map EConstr.of_rel_decl ctx in diff --git a/src/coq_elpi_HOAS.mli b/src/coq_elpi_HOAS.mli index f85c7d3a5..ca2405cfd 100644 --- a/src/coq_elpi_HOAS.mli +++ b/src/coq_elpi_HOAS.mli @@ -61,7 +61,7 @@ val lp2inductive_entry : State.t * (Entries.mutual_inductive_entry * record_field_spec list option * DeclareInd.one_inductive_impls list) * Conversion.extra_goals val inductive_decl2lp : - depth:int -> coq_context -> constraints -> State.t -> ((Declarations.mutual_inductive_body * Declarations.one_inductive_body) * (Impargs.implicit_kind list * Impargs.implicit_kind list list)) -> + depth:int -> coq_context -> constraints -> State.t -> ((Declarations.mutual_inductive_body * Declarations.one_inductive_body) * (Glob_term.binding_kind list * Glob_term.binding_kind list list)) -> State.t * term * Conversion.extra_goals val in_elpi_id : Names.Name.t -> term @@ -98,8 +98,8 @@ val in_elpi_name : Name.t -> term val in_coq_name : depth:int -> term -> Name.t val is_coq_name : depth:int -> term -> bool -val in_coq_imp : depth:int -> State.t -> term -> State.t * Impargs.implicit_kind -val in_elpi_imp : depth:int -> State.t -> Impargs.implicit_kind -> State.t * term +val in_coq_imp : depth:int -> State.t -> term -> State.t * Glob_term.binding_kind +val in_elpi_imp : depth:int -> State.t -> Glob_term.binding_kind -> State.t * term (* for quotations *) val in_elpi_app_Arg : depth:int -> term -> term list -> term @@ -112,7 +112,7 @@ val constant : global_constant Conversion.t val universe : Sorts.t Conversion.t val global_constant_of_globref : Names.GlobRef.t -> global_constant val abbreviation : Globnames.syndef_name Conversion.t -val implicit_kind : Impargs.implicit_kind Conversion.t +val implicit_kind : Glob_term.binding_kind Conversion.t module GRMap : Elpi.API.Utils.Map.S with type key = Names.GlobRef.t module GRSet : Elpi.API.Utils.Set.S with type elt = Names.GlobRef.t diff --git a/src/coq_elpi_builtins.ml b/src/coq_elpi_builtins.ml index ad4669847..36bb55b68 100644 --- a/src/coq_elpi_builtins.ml +++ b/src/coq_elpi_builtins.ml @@ -449,8 +449,8 @@ let coercion = let open Conv in let open API.AlgebraicData in declare { ] } |> CConv.(!<) -let binding_kind : Glob_term.binding_kind Conv.t = let open Conv in let open API.AlgebraicData in let open Glob_term in declare { - ty = TyName "binding_kind"; +let implicit_kind : Glob_term.binding_kind Conv.t = let open Conv in let open API.AlgebraicData in let open Glob_term in declare { + ty = TyName "implicit_kind"; doc = "Implicit status of an argument"; pp = (fun fmt -> function | NonMaxImplicit -> Format.fprintf fmt "implicit" @@ -469,7 +469,7 @@ let binding_kind : Glob_term.binding_kind Conv.t = let open Conv in let open API ] } |> CConv.(!<) -let binding_kind_of_status = function +let implicit_kind_of_status = function | None -> Glob_term.Explicit | Some (_,_,(maximal,_)) -> if maximal then Glob_term.MaxImplicit else Glob_term.NonMaxImplicit @@ -952,7 +952,7 @@ It undestands qualified names, e.g. "Nat.t". It's a fatal error if Name cannot b | Entries.Polymorphic_entry (_,uctx) -> Univ.ContextSet.of_context uctx | Entries.Monomorphic_entry uctx -> uctx in context_set_of_entry uentry in - Declare.declare_universe_context ~poly:false uctx; + DeclareUctx.declare_universe_context ~poly:false uctx; ComAssumption.declare_variable false ~kind (EConstr.to_constr sigma ty) impargs Glob_term.Explicit variable; GlobRef.VarRef(Id.of_string id), Univ.Instance.empty end else @@ -970,8 +970,8 @@ It undestands qualified names, e.g. "Nat.t". It's a fatal error if Name cannot b let udecl = UState.default_univ_decl in let kind = Decls.(IsDefinition Definition) in let scope = if local - then DeclareDef.Discharge - else DeclareDef.Global Declare.ImportDefaultBehavior in + then Declare.Discharge + else Declare.Global Declare.ImportDefaultBehavior in let gr = DeclareDef.declare_definition ~name:(Id.of_string id) ~scope ~kind ~impargs:[] ~poly:false ~udecl ~opaque:(opaque = Given true) ~types ~body sigma @@ -1337,20 +1337,20 @@ denote the same x as before.|}; LPDoc "-- Coq's notational mechanisms -------------------------------------"; - MLData binding_kind; + MLData implicit_kind; MLCode(Pred("coq.arguments.implicit", In(gref,"GR", - Out(list (list binding_kind),"Imps", + Out(list (list implicit_kind),"Imps", Easy "reads the implicit arguments declarations associated to a global reference. See also the [] and {} flags for the Arguments command.")), (fun gref _ ~depth -> - !: (List.map (fun (_,x) -> List.map binding_kind_of_status x) + !: (List.map (fun (_,x) -> List.map implicit_kind_of_status x) (Impargs.extract_impargs_data (Impargs.implicits_of_global gref))))), DocAbove); MLCode(Pred("coq.arguments.set-implicit", In(gref,"GR", - In(list (list (unspec binding_kind)),"Imps", + In(list (list (unspec implicit_kind)),"Imps", In(flag "global?", "Global", Full(unit_ctx, {|sets the implicit arguments declarations associated to a global reference. diff --git a/src/coq_elpi_glob_quotation.ml b/src/coq_elpi_glob_quotation.ml index 0020051aa..61965f27b 100644 --- a/src/coq_elpi_glob_quotation.ml +++ b/src/coq_elpi_glob_quotation.ml @@ -306,7 +306,7 @@ let rec do_params params kont ~depth state = if ob <> None then Coq_elpi_utils.nYI "defined parameters in a record/inductive declaration"; let state, src = gterm2lp ~depth state src in let state, tgt = under_ctx name src None (do_params params kont) ~depth state in - let state, imp = in_elpi_imp ~depth state (implicit_kind_of_binding_kind imp) in + let state, imp = in_elpi_imp ~depth state imp in state, in_elpi_parameter name ~imp src tgt let do_arity t ~depth state = diff --git a/src/coq_elpi_goal_HOAS.ml b/src/coq_elpi_goal_HOAS.ml index e89ce66dd..1fda4a176 100644 --- a/src/coq_elpi_goal_HOAS.ml +++ b/src/coq_elpi_goal_HOAS.ml @@ -148,7 +148,7 @@ let rec do_context fields ~depth state = let state, bo = option_map_acc (gterm2lp ~depth) state bo in let state, fields = under_ctx name ty bo (do_context fields) ~depth state in let state, bo, _ = in_option ~depth state bo in - let state, imp = in_elpi_imp ~depth state (Coq_elpi_utils.implicit_kind_of_binding_kind bk) in + let state, imp = in_elpi_imp ~depth state bk in state, E.mkApp ctxitemc (in_elpi_id name) [imp;ty;bo;E.mkLam fields] let strc = E.Constants.declare_global_symbol "str" diff --git a/src/coq_elpi_utils.ml b/src/coq_elpi_utils.ml index 6c1c3baa6..d132be6fd 100644 --- a/src/coq_elpi_utils.ml +++ b/src/coq_elpi_utils.ml @@ -93,22 +93,12 @@ let rec mk_gfun ty = function | (name,_,Some bo,t) :: ps -> DAst.make @@ Glob_term.GLetIn(name,bo,Some t, mk_gfun ty ps) | [] -> ty -let manual_implicit_of_biding_kind name = function - (* | Glob_term.NonMaxImplicit -> CAst.make (Some (na,false)) :: impls *) - | Glob_term.Implicit -> CAst.make (Some (name,true)) +let manual_implicit_of_binding_kind name = function + | Glob_term.NonMaxImplicit -> CAst.make (Some (name,false)) + | Glob_term.MaxImplicit -> CAst.make (Some (name,true)) | Glob_term.Explicit -> CAst.make None -let manual_implicit_of_gdecl (name,bk,_,_) = manual_implicit_of_biding_kind name bk - -let implicit_kind_of_binding_kind = function - (* | Glob_term.NonMaxImplicit -> ... *) - | Glob_term.Implicit -> Impargs.MaximallyImplicit - | Glob_term.Explicit -> Impargs.NotImplicit - -let manual_implicit_of_implicit_kind name = function - | Impargs.MaximallyImplicit -> CAst.make (Some (name,true)) - | Impargs.Implicit -> CAst.make (Some (name,false)) - | Impargs.NotImplicit -> CAst.make None +let manual_implicit_of_gdecl (name,bk,_,_) = manual_implicit_of_binding_kind name bk let lookup_inductive env i = let mind, indbo = Inductive.lookup_mind_specif env i in diff --git a/src/coq_elpi_utils.mli b/src/coq_elpi_utils.mli index 203d4501f..aebbd67ed 100644 --- a/src/coq_elpi_utils.mli +++ b/src/coq_elpi_utils.mli @@ -17,8 +17,6 @@ val mkApp : depth:int -> Elpi.API.RawData.term -> Elpi.API.RawData.term list -> val string_split_on_char : char -> string -> string list val mk_gforall : Glob_term.glob_constr -> Glob_term.glob_decl list -> Glob_term.glob_constr val mk_gfun : Glob_term.glob_constr -> Glob_term.glob_decl list -> Glob_term.glob_constr -val manual_implicit_of_biding_kind : Names.Name.t -> Glob_term.binding_kind -> (Names.Name.t * bool) option CAst.t +val manual_implicit_of_binding_kind : Names.Name.t -> Glob_term.binding_kind -> (Names.Name.t * bool) option CAst.t val manual_implicit_of_gdecl : Glob_term.glob_decl -> (Names.Name.t * bool) option CAst.t -val implicit_kind_of_binding_kind : Glob_term.binding_kind -> Impargs.implicit_kind -val manual_implicit_of_implicit_kind : Names.Name.t -> Impargs.implicit_kind -> (Names.Name.t * bool) option CAst.t val lookup_inductive : Environ.env -> Names.inductive -> Declarations.mutual_inductive_body * Declarations.one_inductive_body \ No newline at end of file diff --git a/src/coq_elpi_vernacular.ml b/src/coq_elpi_vernacular.ml index 7756494ec..0dd9dfbe0 100644 --- a/src/coq_elpi_vernacular.ml +++ b/src/coq_elpi_vernacular.ml @@ -119,7 +119,7 @@ let push_inductive_in_intern_env intern_env name params arity user_impls = let sigma = Evd.from_env env in let sigma, ty = Pretyping.understand_tcc env sigma ~expected_type:Pretyping.IsType (Coq_elpi_utils.mk_gforall arity params) in Constrintern.compute_internalization_env env sigma ~impls:intern_env - (Constrintern.Inductive([],true(* dummy *))) [name] [ty] [user_impls] + Constrintern.Inductive [name] [ty] [user_impls] let intern_tactic_constr = Ltac_plugin.Tacintern.intern_constr From d65839486622af94a4069cf3dfca9d10bef33a66 Mon Sep 17 00:00:00 2001 From: Enrico Tassi Date: Fri, 12 Jun 2020 17:32:55 +0200 Subject: [PATCH 20/24] [coq] disable memory hog tests --- theories/derive/tests/test_bcongr.v | 4 ++-- theories/derive/tests/test_eqK.v | 4 ++-- theories/derive/tests/test_eqOK.v | 4 ++-- theories/derive/tests/test_eqcorrect.v | 4 ++-- 4 files changed, 8 insertions(+), 8 deletions(-) diff --git a/theories/derive/tests/test_bcongr.v b/theories/derive/tests/test_bcongr.v index 37dba5573..fcfaf52aa 100644 --- a/theories/derive/tests/test_bcongr.v +++ b/theories/derive/tests/test_bcongr.v @@ -20,7 +20,7 @@ Fail Elpi derive.bcongr dyn. Elpi derive.bcongr zeta. Elpi derive.bcongr beta. Fail Elpi derive.bcongr iota. -Elpi derive.bcongr large. +(* Elpi derive.bcongr large. *) End Coverage. Import Coverage. @@ -60,4 +60,4 @@ Check beta_bcongr_Redex : forall A x y b, reflect (x = y) b -> reflect (Redex A Fail Check iota_bcongr_Why. -Check large_bcongr_K1. +(* Check large_bcongr_K1. *) diff --git a/theories/derive/tests/test_eqK.v b/theories/derive/tests/test_eqK.v index 5a5510eeb..90f08f0c6 100644 --- a/theories/derive/tests/test_eqK.v +++ b/theories/derive/tests/test_eqK.v @@ -28,7 +28,7 @@ Fail Elpi derive.eqK dyn. Elpi derive.eqK zeta. Elpi derive.eqK beta. Fail Elpi derive.eqK iota. -Elpi derive.eqK large. +(*Elpi derive.eqK large.*) End Coverage. @@ -55,4 +55,4 @@ Check eq_axiom_Envelope. Check eq_axiom_Redex. -Check eq_axiom_K1. \ No newline at end of file +(*Check eq_axiom_K1.*) \ No newline at end of file diff --git a/theories/derive/tests/test_eqOK.v b/theories/derive/tests/test_eqOK.v index 0bd98972b..0d17772ac 100644 --- a/theories/derive/tests/test_eqOK.v +++ b/theories/derive/tests/test_eqOK.v @@ -24,7 +24,7 @@ Fail Elpi derive.eqOK dyn. Elpi derive.eqOK zeta. Elpi derive.eqOK beta. Fail Elpi derive.eqOK iota. -Elpi derive.eqOK large. +(* Elpi derive.eqOK large. *) End Coverage. Import Coverage. @@ -45,7 +45,7 @@ Fail Check dyn_eq_OK. Check zeta_eq_OK : forall A f, ok A f -> ok (zeta A) (zeta_eq A f). Check beta_eq_OK : forall A f, ok A f -> ok (beta A) (beta_eq A f). Fail Check iota_eq_OK. -Check large_eq_OK : ok large large_eq. +(* Check large_eq_OK : ok large large_eq. *) From elpi Require Import test_param1_functor. Import test_param1_functor.Coverage. diff --git a/theories/derive/tests/test_eqcorrect.v b/theories/derive/tests/test_eqcorrect.v index 98ca2d2d8..ef68fadcd 100644 --- a/theories/derive/tests/test_eqcorrect.v +++ b/theories/derive/tests/test_eqcorrect.v @@ -26,7 +26,7 @@ Fail Elpi derive.eqcorrect dyn. Elpi derive.eqcorrect zeta. Elpi derive.eqcorrect beta. Fail Elpi derive.eqcorrect iota. -Elpi derive.eqcorrect large. +(* Elpi derive.eqcorrect large. *) End Coverage. Import Coverage. @@ -47,5 +47,5 @@ Fail Check dyn_eq_correct. Check zeta_eq_correct : forall A f, correct (zeta A) (is_zeta A (eq_axiom_at A f)) (zeta_eq A f). Check beta_eq_correct : forall A f, correct (beta A) (is_beta A (eq_axiom_at A f)) (beta_eq A f). Fail Check iota_eq_correct. -Check large_eq_correct : correct large is_large large_eq. +(* Check large_eq_correct : correct large is_large large_eq. *) From c10bde2f18f42d67803077e6f18cd85a944dfe2d Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Ga=C3=ABtan=20Gilbert?= Date: Tue, 7 Jul 2020 12:16:25 +0200 Subject: [PATCH 21/24] Adapt to coq/coq#12650 (cleanup declare_structure_entry) --- src/coq_elpi_builtins.ml | 16 +++++++++++----- 1 file changed, 11 insertions(+), 5 deletions(-) diff --git a/src/coq_elpi_builtins.ml b/src/coq_elpi_builtins.ml index 173873ea0..0abbb14fe 100644 --- a/src/coq_elpi_builtins.ml +++ b/src/coq_elpi_builtins.ml @@ -998,19 +998,25 @@ It undestands qualified names, e.g. "Nat.t". It's a fatal error if Name cannot b { Record.pf_subclass = is_coercion ; pf_canonical = is_canonical }) field_specs)) in let is_implicit = List.map (fun _ -> []) names in - let rsp = ind in - let cstr = (rsp,1) in + let cstr = (ind,1) in let open Entries in let k_ty = List.(hd (hd me.mind_entry_inds).mind_entry_lc) in let fields_as_relctx = Term.prod_assum k_ty in let kinds, sp_projs = - Record.declare_projections rsp ~kind:Decls.Definition + Record.declare_projections ind ~kind:Decls.Definition (Evd.univ_entry ~poly:false sigma) (Names.Id.of_string "record") flags is_implicit fields_as_relctx in - Record.declare_structure_entry - (cstr, List.rev kinds, List.rev sp_projs); + let npars = Inductiveops.inductive_nparams (Global.env()) ind in + let struc = { + Recordops.s_CONST = cstr; + s_PROJ = List.rev sp_projs; + s_PROJKIND = List.rev kinds; + s_EXPECTEDPARAM = npars; + } + in + Record.declare_structure_entry struc; end; state, !: ind, []))), DocAbove); From 7fa282cc0de61d11d8aee06b8e385ee640b53eb2 Mon Sep 17 00:00:00 2001 From: Enrico Tassi Date: Tue, 28 Jul 2020 11:38:52 +0200 Subject: [PATCH 22/24] [api] support @local! in coq.CS.declare-instance (new in Coq 8.12) --- Changelog.md | 7 +++++++ coq-builtin.elpi | 5 ++++- src/coq_elpi_builtins.ml | 8 +++++--- theories/tests/test_API.v | 14 ++++++++++++++ 4 files changed, 30 insertions(+), 4 deletions(-) diff --git a/Changelog.md b/Changelog.md index 039f19cad..4748856f3 100644 --- a/Changelog.md +++ b/Changelog.md @@ -2,6 +2,13 @@ ## UNRELEASED +Requires Elpi 1.11 and Coq 8.12. + +### API: + Locality is now supported by `coq.CS.declare-instance` + +## UNRELEASED + ### HOAS - New option `@holes!` to be assumed (as in `@holes! => ...`) before calling any Coq API. When this option is given unknown unification variables diff --git a/coq-builtin.elpi b/coq-builtin.elpi index f92f82837..0616df4d1 100644 --- a/coq-builtin.elpi +++ b/coq-builtin.elpi @@ -647,7 +647,10 @@ type cs-sort universe -> cs-pattern. kind cs-instance type. type cs-instance gref -> cs-pattern -> term -> cs-instance. -% [coq.CS.declare-instance GR] declares GR as a canonical structure instance +% [coq.CS.declare-instance GR] Declares GR as a canonical structure +% instance. +% Supported attributes: +% - @local! (default: false) external pred coq.CS.declare-instance i:gref. % [coq.CS.db Db] reads all instances diff --git a/src/coq_elpi_builtins.ml b/src/coq_elpi_builtins.ml index 4d0531c28..e39077903 100644 --- a/src/coq_elpi_builtins.ml +++ b/src/coq_elpi_builtins.ml @@ -1241,9 +1241,11 @@ denote the same x as before.|}; MLCode(Pred("coq.CS.declare-instance", In(gref, "GR", - Full(unit_ctx, "declares GR as a canonical structure instance")), - (fun gr ~depth _ _ -> on_global_state "coq.CS.declare-instance" (fun state -> - Canonical.declare_canonical_structure gr; + Full(global, {|Declares GR as a canonical structure instance. +Supported attributes: +- @local! (default: false)|})), + (fun gr ~depth { options } _ -> on_global_state "coq.CS.declare-instance" (fun state -> + Canonical.declare_canonical_structure ?local:options.local gr; state, (), []))), DocAbove); diff --git a/theories/tests/test_API.v b/theories/tests/test_API.v index e9a9b1a91..84806cd63 100644 --- a/theories/tests/test_API.v +++ b/theories/tests/test_API.v @@ -446,6 +446,20 @@ Elpi Query lp:{{ coq.locate "eq_op" (const P2) }}. +Axiom W1 : Type. +Axiom Z1 : W1 -> W1 -> bool. +Axiom t1 : W1. + +Definition myc1 : eq := mk_eq W1 Z1 3. + +Section CStest. +Elpi Query lp:{{ coq.locate "myc1" GR, @local! => coq.CS.declare-instance GR. }}. +Check (eq_op _ t1 t1). +End CStest. + +Fail Check (eq_op _ t1 t1). + + (****** Coercions **********************************) Axiom C1 : Type. From ebafc14b5374db932680914217c2753e60798a47 Mon Sep 17 00:00:00 2001 From: Enrico Tassi Date: Tue, 28 Jul 2020 15:57:48 +0200 Subject: [PATCH 23/24] context readback global syncs the evar map --- src/coq_elpi_HOAS.ml | 11 ++++++----- src/coq_elpi_HOAS.mli | 4 ++-- src/coq_elpi_builtins.ml | 30 ++++++++++++++---------------- src/coq_elpi_vernacular.ml | 2 +- 4 files changed, 23 insertions(+), 24 deletions(-) diff --git a/src/coq_elpi_HOAS.ml b/src/coq_elpi_HOAS.ml index 3d0f5ec9a..05c8f3086 100644 --- a/src/coq_elpi_HOAS.ml +++ b/src/coq_elpi_HOAS.ml @@ -1341,11 +1341,6 @@ let pop_env state = S.update engine state (fun ({ global_env } as x) -> { x with global_env = Environ.pop_rel_context 1 global_env }) -let get_global_env_sigma state = - let { global_env; sigma } = S.get engine state in - Environ.push_context_set (Evd.universe_context_set sigma) global_env, sigma - - let set_sigma state sigma = S.update engine state (fun x -> { x with sigma }) (* We reset the evar map since it depends on the env in which it was created *) @@ -2197,6 +2192,12 @@ let get_current_env_sigma ~depth hyps constraints state = of_elpi_ctx ~calldepth:depth constraints depth (preprocess_context (fun _ -> true) (E.of_hyps hyps)) state (mk_coq_context ~options:(get_options ~depth hyps state) state) in state, coq_ctx, get_sigma state, gl1 @ gl2 ;; +let get_global_env_current_sigma ~depth hyps constraints state = + let state, _, changed, gls = elpi_solution_to_coq_solution constraints state in + let coq_ctx = mk_coq_context ~options:(get_options ~depth hyps state) state in + let coq_ctx = { coq_ctx with env = Environ.push_context_set (Evd.universe_context_set (get_sigma state)) coq_ctx.env } in + state, coq_ctx, get_sigma state, gls +;; let constr2lp ~depth coq_ctx _constraints state t = constr2lp coq_ctx ~calldepth:depth ~depth state t diff --git a/src/coq_elpi_HOAS.mli b/src/coq_elpi_HOAS.mli index db1bb6cee..b1ed724ac 100644 --- a/src/coq_elpi_HOAS.mli +++ b/src/coq_elpi_HOAS.mli @@ -45,6 +45,8 @@ val upcast : [> `Options ] coq_context -> full coq_context val get_current_env_sigma : depth:int -> Data.hyps -> constraints -> State.t -> State.t * full coq_context * Evd.evar_map * Conversion.extra_goals val set_current_sigma : depth:int -> State.t -> Evd.evar_map -> State.t * Conversion.extra_goals +val get_global_env_current_sigma : depth:int -> + Data.hyps -> constraints -> State.t -> State.t * empty coq_context * Evd.evar_map * Conversion.extra_goals (* HOAS of terms *) val constr2lp : @@ -66,8 +68,6 @@ val constr2lp_closed_ground : depth:int -> State.t -> val lp2constr_closed_ground : depth:int -> State.t -> term -> State.t * EConstr.t * Conversion.extra_goals -val get_global_env_sigma : State.t -> Environ.env * Evd.evar_map - type record_field_spec = { name : Name.t; is_coercion : bool; is_canonical : bool } val lp2inductive_entry : diff --git a/src/coq_elpi_builtins.ml b/src/coq_elpi_builtins.ml index e39077903..37cead89e 100644 --- a/src/coq_elpi_builtins.ml +++ b/src/coq_elpi_builtins.ml @@ -189,9 +189,8 @@ let closed_term = { } let global : (empty coq_context, API.Data.constraints) CConv.ctx_readback = fun ~depth hyps constraints state -> - let env, _ = get_global_env_sigma state in (* this env has more univ constraints *) - let coq_ctx = mk_coq_context ~options:(get_options ~depth hyps state) state in - state, { coq_ctx with env }, constraints, [] + let state, proof_context, _, gls = get_global_env_current_sigma ~depth hyps constraints state in + state, proof_context, constraints, gls let closed_ground_term = { Conv.ty = Conv.TyName "term"; @@ -569,11 +568,11 @@ let gr2path state gr = | Names.GlobRef.ConstRef c -> (mp2sl @@ Constant.modpath c) | Names.GlobRef.IndRef (i,0) -> let open Declarations in - let env, sigma = get_global_env_sigma state in + let env = get_global_env state in let { mind_packets } = Environ.lookup_mind i env in ((mp2sl @@ MutInd.modpath i) @ [ Id.to_string (mind_packets.(0).mind_typename)]) | Names.GlobRef.ConstructRef ((i,0),j) -> - let env, sigma = get_global_env_sigma state in + let env = get_global_env state in let open Declarations in let { mind_packets } = Environ.lookup_mind i env in let klbl = Id.to_string (mind_packets.(0).mind_consnames.(j-1)) in @@ -1292,10 +1291,9 @@ Supported attributes: MLCode(Pred("coq.TC.db-for", In(gref, "GR", Out(list tc_instance, "Db", - Read(unit_ctx,"reads all instances of the given class GR"))), - (fun gr _ ~depth _ _ state -> - let env, evd = get_global_env_sigma state in - !: (Typeclasses.instances env evd gr))), + Read(global,"reads all instances of the given class GR"))), + (fun gr _ ~depth { env } _ state -> + !: (Typeclasses.instances env (get_sigma state) gr))), DocAbove); MLCode(Pred("coq.TC.class?", @@ -1553,8 +1551,8 @@ Supported attributes: In(abbreviation,"Abbreviation", In(B.list (B.poly "term"),"Args", Out(B.poly "term","Body", - Full(unit_ctx, "Unfolds an abbreviation")))), - (fun sd arglist _ ~depth proof_context _ state -> + Full(global, "Unfolds an abbreviation")))), + (fun sd arglist _ ~depth {env} _ state -> let args, _ = Syntax_def.search_syntactic_definition sd in let nargs = List.length args in let open Constrexpr in @@ -1564,7 +1562,7 @@ Supported attributes: CLocalAssum([lname],Default Glob_term.Explicit, CAst.make @@ CHole(None,Namegen.IntroAnonymous,None)), (CAst.make @@ CRef(Libnames.qualid_of_string name,None), None))) in let eta = CAst.(make @@ CLambdaN(binders,make @@ CApp((None,make @@ CRef(Libnames.qualid_of_string (KerName.to_string sd),None)),vars))) in - let env, sigma = get_global_env_sigma state in + let sigma = get_sigma state in let geta = Constrintern.intern_constr env sigma eta in let state, teta = Coq_elpi_glob_quotation.gterm2lp ~depth state geta in let t = @@ -1584,7 +1582,7 @@ Supported attributes: Out(B.int,"Nargs", Out(B.poly "term","Body", Full(global, "Retrieves the body of an abbreviation")))), - (fun sd _ _ ~depth proof_context _ state -> + (fun sd _ _ ~depth {env} _ state -> let args, _ = Syntax_def.search_syntactic_definition sd in let nargs = List.length args in let open Constrexpr in @@ -1594,7 +1592,7 @@ Supported attributes: CLocalAssum([lname],Default Glob_term.Explicit, CAst.make @@ CHole(None,Namegen.IntroAnonymous,None)), (CAst.make @@ CRef(Libnames.qualid_of_string name,None), None))) in let eta = CAst.(make @@ CLambdaN(binders,make @@ CApp((None,make @@ CRef(Libnames.qualid_of_string (KerName.to_string sd),None)),vars))) in - let env, sigma = get_global_env_sigma state in + let sigma = get_sigma state in let geta = Constrintern.intern_constr env sigma eta in let state, teta = Coq_elpi_glob_quotation.gterm2lp ~depth state geta in state, !: nargs +! teta, [] @@ -1827,12 +1825,12 @@ coq.id->name S N :- coq.string->name S N. !: (Id.to_string (Label.to_id (Constant.label c))) | IndRef (i,0) -> let open Declarations in - let env, sigma = get_global_env_sigma state in + let env = get_global_env state in let { mind_packets } = Environ.lookup_mind i env in !: (Id.to_string (mind_packets.(0).mind_typename)) | ConstructRef ((i,0),j) -> let open Declarations in - let env, sigma = get_global_env_sigma state in + let env = get_global_env state in let { mind_packets } = Environ.lookup_mind i env in !: (Id.to_string (mind_packets.(0).mind_consnames.(j-1))) | IndRef _ | ConstructRef _ -> diff --git a/src/coq_elpi_vernacular.ml b/src/coq_elpi_vernacular.ml index a87c93732..78d54079e 100644 --- a/src/coq_elpi_vernacular.ml +++ b/src/coq_elpi_vernacular.ml @@ -628,7 +628,7 @@ let run_and_print ~tactic_mode ~print ~static_check program_ast query_ast = let scst = pp2string (EPP.constraints pp_ctx) constraints in if scst <> "" then Feedback.msg_notice Pp.(str"Syntactic constraints:" ++ spc()++str scst); - let _, sigma = Coq_elpi_HOAS.get_global_env_sigma state in + let sigma = Coq_elpi_HOAS.get_sigma state in let ccst = Evd.evar_universe_context sigma in if not (UState.is_empty ccst) then Feedback.msg_notice Pp.(str"Universe constraints:" ++ spc() ++ From 79e07d7df286537306fee7687ed86e7bdffd3925 Mon Sep 17 00:00:00 2001 From: Enrico Tassi Date: Wed, 29 Jul 2020 11:23:12 +0200 Subject: [PATCH 24/24] master goes to 8.12 --- .github/workflows/main.yml | 2 +- Changelog.md | 8 ++++---- coq-elpi.opam | 2 +- 3 files changed, 6 insertions(+), 6 deletions(-) diff --git a/.github/workflows/main.yml b/.github/workflows/main.yml index 6692de014..5ed02bcb8 100644 --- a/.github/workflows/main.yml +++ b/.github/workflows/main.yml @@ -16,7 +16,7 @@ jobs: strategy: matrix: coq_version: - - '8.11' + - '8.12' ocaml_version: - 'minimal' steps: diff --git a/Changelog.md b/Changelog.md index 0b2572dea..b4fa33132 100644 --- a/Changelog.md +++ b/Changelog.md @@ -1,15 +1,15 @@ # Changelog -## [1.5.0] - 29-07-2020 - -Requires Elpi 1.11 and Coq 8.11. +## [1.5.1] - 29-07-2020 Requires Elpi 1.11 and Coq 8.12. ### API: Locality is now supported by `coq.CS.declare-instance` -## UNRELEASED +## [1.5.0] - 29-07-2020 + +Requires Elpi 1.11 and Coq 8.11. ### HOAS - New option `@holes!` to be assumed (as in `@holes! => ...`) before diff --git a/coq-elpi.opam b/coq-elpi.opam index 41b40796c..e24f49693 100644 --- a/coq-elpi.opam +++ b/coq-elpi.opam @@ -12,7 +12,7 @@ build: [ make "COQBIN=%{bin}%/" "ELPIDIR=%{prefix}%/lib/elpi" ] install: [ make "install" "COQBIN=%{bin}%/" "ELPIDIR=%{prefix}%/lib/elpi" ] depends: [ "elpi" {>= "1.11.0" & < "1.12.0~"} - "coq" {= "dev" } + "coq" {>= "8.12" & < "8.13~" } ] synopsis: "Elpi extension language for Coq" description: """