From f689bade7dc0ccd21d71731792f7daedb112c723 Mon Sep 17 00:00:00 2001 From: MathisBD Date: Thu, 12 Dec 2024 14:34:40 +0100 Subject: [PATCH 1/4] add documentation in common/Environment.v --- common/theories/Environment.v | 73 +++++++++++++++++++++-------- common/theories/EnvironmentTyping.v | 2 +- 2 files changed, 55 insertions(+), 20 deletions(-) diff --git a/common/theories/Environment.v b/common/theories/Environment.v index f8de029a1..b5c0a3298 100644 --- a/common/theories/Environment.v +++ b/common/theories/Environment.v @@ -218,7 +218,9 @@ Module Environment (T : Term). decl_body := decl_body x; decl_type := decl_type x |}. - Fixpoint context_assumptions (Γ : context) := + (** Count the number of assumptions in a context (i.e. declarations that do not + contain a body). *) + Fixpoint context_assumptions (Γ : context) : nat := match Γ with | [] => 0 | d :: Γ => @@ -313,23 +315,33 @@ Module Environment (T : Term). (** *** Environments *) + (** Data associated to a single inductive constructor. *) Record constructor_body := { + (** Constructor name, without the module path. *) cstr_name : ident; - (* The arguments and indices are typeable under the context of - arities of the mutual inductive + parameters *) + (** Arguments of the constructor, which can depend on the inductives in the same block + and the parameters of the inductive. *) cstr_args : context; + (** Indices of the constructor, which can depend on the inductives in the same block, + the parameters of the inductive and the constructor arguments. *) cstr_indices : list term; + (** Full type of the constructor, which can depend on the inductives in the same block. + This should be equal to `forall mind_params cstr_args, I mind_params cstr_indices` *) cstr_type : term; - (* Closed type: on well-formed constructors: forall params, cstr_args, I params cstr_indices *) - cstr_arity : nat; (* arity, w/o lets, w/o parameters *) + (** Number of arguments of the constructor, _without_ let-in arguments and _without_ parameters. + This should be equal to `context_assumptions cstr_args`. *) + cstr_arity : nat; }. + (** Data associated to a primitive projection. *) Record projection_body := { + (** Projection name, without the module path. *) proj_name : ident; - (* The arguments and indices are typeable under the context of - arities of the mutual inductive + parameters *) + (** Relevance of the projection. *) proj_relevance : relevance; - proj_type : term; (* Type under context of params and inductive object *) + (** Type of the projection, wich can depend on the parameters of the inductive + and on the object we are projecting from. *) + proj_type : term; }. Definition map_constructor_body npars arities f c := @@ -341,23 +353,32 @@ Module Environment (T : Term). cstr_type := f arities c.(cstr_type); cstr_arity := c.(cstr_arity) |}. - (* Here npars should be the [context_assumptions] of the parameters context. *) + (** Here npars should be the [context_assumptions] of the parameters context. *) Definition map_projection_body npars f c := {| proj_name := c.(proj_name); proj_relevance := c.(proj_relevance); proj_type := f (S npars) c.(proj_type) |}. - (** See [one_inductive_body] from [declarations.ml]. *) + (** Data associated to a single inductive in a mutual inductive block. *) Record one_inductive_body := { - ind_name : ident; - ind_indices : context; (* Indices of the inductive types, under params *) - ind_sort : Sort.t; (* Sort of the inductive. *) - ind_type : term; (* Closed arity = forall mind_params, ind_indices, tSort ind_sort *) - ind_kelim : allowed_eliminations; (* Allowed eliminations *) + (** Name of the inductive, without the module path. *) + ind_name : ident; + (** Indices of the inductive type, which can depend on the parameters of the inductive. *) + ind_indices : context; + (** Sort of the inductive. *) + ind_sort : Sort.t; + (** Full type of the inductive. This should be equal to + `forall mind_params ind_indices, tSort ind_sort` *) + ind_type : term; + (** Allowed eliminations for this inductive. *) + ind_kelim : allowed_eliminations; + (** Constructors of this inductive. Order is important. *) ind_ctors : list constructor_body; - ind_projs : list projection_body; (* names and types of projections, if any. *) - ind_relevance : relevance (* relevance of the inductive definition *) }. + (** Names and types of primitive projections, if any. *) + ind_projs : list projection_body; + (** Relevance of the inductive definition. *) + ind_relevance : relevance }. Definition map_one_inductive_body npars arities f m := match m with @@ -369,20 +390,33 @@ Module Environment (T : Term). (map (map_projection_body npars f) ind_projs) ind_relevance end. - (** See [mutual_inductive_body] from [declarations.ml]. *) + (** Data associated to a block of mutually inductive types. *) Record mutual_inductive_body := { + (** Whether the mutual inductive is inductive, coinductive or non-recursive. *) ind_finite : recursivity_kind; + (** Number of parameters (including non-uniform ones), _without_ counting let-in parameters. + This should be equal to `context_assumptions ind_params`. *) ind_npars : nat; + (** Context of parameters (including non-uniform ones), _with_ let-in parameters. *) ind_params : context; + (** Components of the mutual inductive block. Order is important. *) ind_bodies : list one_inductive_body ; + (** Whether the mutual inductive is universe monomorphic or universe polymorphic, + and information about the local universes if polymorphic. *) ind_universes : universes_decl; + (** Variance information. [None] when non-cumulative. *) ind_variance : option (list Universes.Variance.t) }. - (** See [constant_body] from [declarations.ml] *) + (** Data associated to a constant (definition, lemma, axiom). *) Record constant_body := { + (** Type of this constant. *) cst_type : term; + (** Body of this constant. For axioms this is [None]. *) cst_body : option term; + (** Whether the constant is universe monomorphic or polymorphic, and if polymorphic + information about its local universes. *) cst_universes : universes_decl; + (** Relevance of this constant. *) cst_relevance : relevance }. Definition map_constant_body f decl := @@ -399,6 +433,7 @@ Module Environment (T : Term). option_map f (cst_body decl) = cst_body (map_constant_body f decl). Proof. destruct decl; reflexivity. Qed. + (** A global declaration is a definition, lemma, axiom or mutual inductive. *) Inductive global_decl := | ConstantDecl : constant_body -> global_decl | InductiveDecl : mutual_inductive_body -> global_decl. diff --git a/common/theories/EnvironmentTyping.v b/common/theories/EnvironmentTyping.v index ff7df2e95..720e4eb00 100644 --- a/common/theories/EnvironmentTyping.v +++ b/common/theories/EnvironmentTyping.v @@ -1261,7 +1261,7 @@ Module GlobalMaps (T: Term) (E: EnvironmentSig T) (TU : TermUtils T E) (ET: EnvT *) (** A constructor argument type [t] is positive w.r.t. an inductive block [mdecl] - when it's zeta-normal form is of the shape Π Δ. concl and: + when it's zeta-normal form is of the shape Π Δ. concl and: - [t] does not refer to any inductive in the block. In that case [t] must be a closed type under the context of parameters and previous arguments. From ec558e4f6bfad5bcbe2a85bf473a2563e193d669 Mon Sep 17 00:00:00 2001 From: MathisBD Date: Mon, 30 Dec 2024 16:38:38 +0100 Subject: [PATCH 2/4] update documentation --- common/theories/Environment.v | 37 +++++++++++++++++++---------------- 1 file changed, 20 insertions(+), 17 deletions(-) diff --git a/common/theories/Environment.v b/common/theories/Environment.v index b5c0a3298..b7c5005fe 100644 --- a/common/theories/Environment.v +++ b/common/theories/Environment.v @@ -320,13 +320,15 @@ Module Environment (T : Term). (** Constructor name, without the module path. *) cstr_name : ident; (** Arguments of the constructor, which can depend on the inductives in the same block - and the parameters of the inductive. *) + and the parameters of the inductive : `ind_bodies ,,, ind_params |- cstr_args`. *) cstr_args : context; (** Indices of the constructor, which can depend on the inductives in the same block, - the parameters of the inductive and the constructor arguments. *) + the parameters of the inductive and the constructor arguments : + `ind_bodies ,,, ind_params ,,, cstr_args |- cstr_indices`. *) cstr_indices : list term; - (** Full type of the constructor, which can depend on the inductives in the same block. - This should be equal to `forall mind_params cstr_args, I mind_params cstr_indices` *) + (** Full type of the constructor, which can depend on the inductives in the same block : + `ind_bodies |- cstr_type`. This should be equal to + `forall ind_params cstr_args, I ind_params cstr_indices` *) cstr_type : term; (** Number of arguments of the constructor, _without_ let-in arguments and _without_ parameters. This should be equal to `context_assumptions cstr_args`. *) @@ -340,7 +342,7 @@ Module Environment (T : Term). (** Relevance of the projection. *) proj_relevance : relevance; (** Type of the projection, wich can depend on the parameters of the inductive - and on the object we are projecting from. *) + and on the object we are projecting from : `ind_params ,,, x |- proj_type`. *) proj_type : term; }. @@ -353,7 +355,7 @@ Module Environment (T : Term). cstr_type := f arities c.(cstr_type); cstr_arity := c.(cstr_arity) |}. - (** Here npars should be the [context_assumptions] of the parameters context. *) + (** Here npars should be the `context_assumptions` of the parameters context. *) Definition map_projection_body npars f c := {| proj_name := c.(proj_name); proj_relevance := c.(proj_relevance); @@ -364,20 +366,21 @@ Module Environment (T : Term). Record one_inductive_body := { (** Name of the inductive, without the module path. *) ind_name : ident; - (** Indices of the inductive type, which can depend on the parameters of the inductive. *) + (** Indices of the inductive, which can depend on the parameters : + `ind_params |- ind_indices`. *) ind_indices : context; (** Sort of the inductive. *) ind_sort : Sort.t; (** Full type of the inductive. This should be equal to - `forall mind_params ind_indices, tSort ind_sort` *) + `forall ind_params ind_indices, tSort ind_sort` *) ind_type : term; - (** Allowed eliminations for this inductive. *) + (** Allowed eliminations for the inductive. *) ind_kelim : allowed_eliminations; - (** Constructors of this inductive. Order is important. *) + (** Constructors of the inductive. Order is important. *) ind_ctors : list constructor_body; (** Names and types of primitive projections, if any. *) ind_projs : list projection_body; - (** Relevance of the inductive definition. *) + (** Relevance of the inductive. *) ind_relevance : relevance }. Definition map_one_inductive_body npars arities f m := @@ -392,7 +395,7 @@ Module Environment (T : Term). (** Data associated to a block of mutually inductive types. *) Record mutual_inductive_body := { - (** Whether the mutual inductive is inductive, coinductive or non-recursive. *) + (** Whether the block is inductive, coinductive or non-recursive (Records). *) ind_finite : recursivity_kind; (** Number of parameters (including non-uniform ones), _without_ counting let-in parameters. This should be equal to `context_assumptions ind_params`. *) @@ -404,19 +407,19 @@ Module Environment (T : Term). (** Whether the mutual inductive is universe monomorphic or universe polymorphic, and information about the local universes if polymorphic. *) ind_universes : universes_decl; - (** Variance information. [None] when non-cumulative. *) + (** Variance information. `None` when non-cumulative. *) ind_variance : option (list Universes.Variance.t) }. - (** Data associated to a constant (definition, lemma, axiom). *) + (** Data associated to a constant (definition, lemma or axiom). *) Record constant_body := { - (** Type of this constant. *) + (** Type of the constant. *) cst_type : term; - (** Body of this constant. For axioms this is [None]. *) + (** Body of the constant. For axioms this is [None]. *) cst_body : option term; (** Whether the constant is universe monomorphic or polymorphic, and if polymorphic information about its local universes. *) cst_universes : universes_decl; - (** Relevance of this constant. *) + (** Proof relevance of this constant. *) cst_relevance : relevance }. Definition map_constant_body f decl := From 18aef9e5ce60402ed9a2196a639570daed6f7bfe Mon Sep 17 00:00:00 2001 From: MathisBD Date: Mon, 30 Dec 2024 17:24:25 +0100 Subject: [PATCH 3/4] fix examples/demo.v --- examples/demo.v | 14 ++++++++------ 1 file changed, 8 insertions(+), 6 deletions(-) diff --git a/examples/demo.v b/examples/demo.v index 12fd705f6..98b3f7d13 100644 --- a/examples/demo.v +++ b/examples/demo.v @@ -71,7 +71,7 @@ MetaCoq Quote Definition eo_syntax := Eval compute in even. MetaCoq Quote Definition add'_syntax := Eval compute in add'. (** Reflecting definitions **) -MetaCoq Unquote Definition zero_from_syntax := (Ast.tConstruct (mkInd (MPfile ["Datatypes"; "Init"; "Stdlib"], "nat") 0) 0 []). +MetaCoq Unquote Definition zero_from_syntax := (Ast.tConstruct (mkInd (MPfile ["Datatypes"; "Init"; "Coq"], "nat") 0) 0 []). Set Printing All. (* the function unquote_kn in reify.ml4 is not yet implemented *) @@ -84,7 +84,9 @@ MetaCoq Unquote Definition add_from_syntax := add_syntax. MetaCoq Unquote Definition eo_from_syntax := eo_syntax. Print eo_from_syntax. -Local Notation Nat_module := (MPfile ["Datatypes"; "Init"; "Stdlib"], "nat"). +Local Notation Nat_module := (MPfile ["Datatypes"; "Init"; "Coq"], "nat"). + + MetaCoq Unquote Definition two_from_syntax := (Ast.tApp (Ast.tConstruct (Kernames.mkInd Nat_module 0) 1 nil) (Ast.tApp (Ast.tConstruct (Kernames.mkInd Nat_module 0) 1 nil) @@ -221,7 +223,7 @@ Definition printInductive (q : qualid): TemplateMonad unit := | _ => tmFail ("[" ^ q ^ "] is not an inductive") end. -MetaCoq Run (printInductive "Stdlib.Init.Datatypes.nat"). +MetaCoq Run (printInductive "Coq.Init.Datatypes.nat"). MetaCoq Run (printInductive "nat"). CoInductive cnat : Set := O :cnat | S : cnat -> cnat. @@ -299,8 +301,8 @@ Definition printConstant' (name : qualid): TemplateMonad unit := | _ => tmFail ("[" ^ name ^ "] is not a constant") end. -Fail MetaCoq Run (printInductive "Stdlib.Arith.PeanoNat.Nat.add"). -MetaCoq Run (printConstant' "Stdlib.Arith.PeanoNat.Nat.add"). +Fail MetaCoq Run (printInductive "Coq.Arith.PeanoNat.Nat.add"). +MetaCoq Run (printConstant' "Coq.Arith.PeanoNat.Nat.add"). Fail MetaCoq Run (tmUnquoteTyped (nat -> nat) add_syntax >>= tmPrint). @@ -409,6 +411,6 @@ Definition kername_of_qualid (q : qualid) : TemplateMonad kername := MetaCoq Run (kername_of_qualid "add" >>= tmPrint). MetaCoq Run (kername_of_qualid "BinNat.N.add" >>= tmPrint). -MetaCoq Run (kername_of_qualid "Stdlib.NArith.BinNatDef.N.add" >>= tmPrint). +MetaCoq Run (kername_of_qualid "Coq.NArith.BinNatDef.N.add" >>= tmPrint). MetaCoq Run (kername_of_qualid "N.add" >>= tmPrint). Fail MetaCoq Run (kername_of_qualid "qlskf" >>= tmPrint). From 620af6ce49db7912ca19f5cd7583cef3f0cdce49 Mon Sep 17 00:00:00 2001 From: MathisBD Date: Mon, 30 Dec 2024 19:25:28 +0100 Subject: [PATCH 4/4] fix examples --- examples/demo.v | 17 ++++++++++------- examples/metacoq_tour.v | 2 +- 2 files changed, 11 insertions(+), 8 deletions(-) diff --git a/examples/demo.v b/examples/demo.v index 98b3f7d13..337197ef5 100644 --- a/examples/demo.v +++ b/examples/demo.v @@ -1,6 +1,7 @@ (* Distributed under the terms of the MIT license. *) From MetaCoq.Utils Require Import utils. From MetaCoq.Template Require Import All. +From Coq Require Init. Import MCMonadNotation. @@ -19,7 +20,7 @@ MetaCoq Test Quote (let x := 2 in | S n => n end). -MetaCoq Test Unquote (Ast.tConstruct (mkInd (MPfile ["Datatypes"; "Init"; "Stdlib"], "nat") 0) 0 []). +MetaCoq Test Unquote (Ast.tConstruct (mkInd (MPfile ["Datatypes"; "Init"; "Corelib"], "nat") 0) 0 []). (** Build a definition **) Definition d : Ast.term. @@ -71,7 +72,9 @@ MetaCoq Quote Definition eo_syntax := Eval compute in even. MetaCoq Quote Definition add'_syntax := Eval compute in add'. (** Reflecting definitions **) -MetaCoq Unquote Definition zero_from_syntax := (Ast.tConstruct (mkInd (MPfile ["Datatypes"; "Init"; "Coq"], "nat") 0) 0 []). +Check Coq.Init.Datatypes.nat. +MetaCoq Unquote Definition zero_from_syntax := + (Ast.tConstruct (mkInd (MPfile ["Datatypes"; "Init"; "Corelib"], "nat") 0) 0 []). Set Printing All. (* the function unquote_kn in reify.ml4 is not yet implemented *) @@ -84,7 +87,7 @@ MetaCoq Unquote Definition add_from_syntax := add_syntax. MetaCoq Unquote Definition eo_from_syntax := eo_syntax. Print eo_from_syntax. -Local Notation Nat_module := (MPfile ["Datatypes"; "Init"; "Coq"], "nat"). +Local Notation Nat_module := (MPfile ["Datatypes"; "Init"; "Corelib"], "nat"). @@ -223,7 +226,7 @@ Definition printInductive (q : qualid): TemplateMonad unit := | _ => tmFail ("[" ^ q ^ "] is not an inductive") end. -MetaCoq Run (printInductive "Coq.Init.Datatypes.nat"). +MetaCoq Run (printInductive "Init.Datatypes.nat"). MetaCoq Run (printInductive "nat"). CoInductive cnat : Set := O :cnat | S : cnat -> cnat. @@ -301,8 +304,8 @@ Definition printConstant' (name : qualid): TemplateMonad unit := | _ => tmFail ("[" ^ name ^ "] is not a constant") end. -Fail MetaCoq Run (printInductive "Coq.Arith.PeanoNat.Nat.add"). -MetaCoq Run (printConstant' "Coq.Arith.PeanoNat.Nat.add"). +Fail MetaCoq Run (printInductive "Stdlib.Arith.PeanoNat.Nat.add"). +MetaCoq Run (printConstant' "Stdlib.Arith.PeanoNat.Nat.add"). Fail MetaCoq Run (tmUnquoteTyped (nat -> nat) add_syntax >>= tmPrint). @@ -411,6 +414,6 @@ Definition kername_of_qualid (q : qualid) : TemplateMonad kername := MetaCoq Run (kername_of_qualid "add" >>= tmPrint). MetaCoq Run (kername_of_qualid "BinNat.N.add" >>= tmPrint). -MetaCoq Run (kername_of_qualid "Coq.NArith.BinNatDef.N.add" >>= tmPrint). +MetaCoq Run (kername_of_qualid "Stdlib.NArith.BinNatDef.N.add" >>= tmPrint). MetaCoq Run (kername_of_qualid "N.add" >>= tmPrint). Fail MetaCoq Run (kername_of_qualid "qlskf" >>= tmPrint). diff --git a/examples/metacoq_tour.v b/examples/metacoq_tour.v index 02e69f5e7..f100e26e9 100644 --- a/examples/metacoq_tour.v +++ b/examples/metacoq_tour.v @@ -28,7 +28,7 @@ Definition foo := (fun x : nat => fun x : nat => x). MetaCoq Quote Definition reifx' := Eval compute in (fun x : nat => let y := x in fun x : nat => y). Print reifx'. MetaCoq Unquote Definition x := - (Ast.tConstruct (mkInd (MPfile ["Datatypes"; "Init"; "Stdlib"], "nat") 0) 0 []). + (Ast.tConstruct (mkInd (MPfile ["Datatypes"; "Init"; "Corelib"], "nat") 0) 0 []). MetaCoq Run (tmBind (tmQuote (3 + 3)) tmPrint).