blob: 8da4e2885ca4fcfb85ec2ea00f93d6a83d5a5004 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
|
(************************************************************************)
(* * The Coq Proof Assistant / The Coq Development Team *)
(* v * INRIA, CNRS and contributors - Copyright 1999-2019 *)
(* <O___,, * (see CREDITS file for the list of authors) *)
(* \VV/ **************************************************************)
(* // * This file is distributed under the terms of the *)
(* * GNU Lesser General Public License Version 2.1 *)
(* * (see LICENSE file for the text of the license) *)
(************************************************************************)
open Environ
open Entries
open Declarations
(** Type checking for some inductive entry.
Returns:
- environment with inductives + parameters in rel context
- abstracted universes
- checked variance info
- record entry (checked to be OK)
- parameters
- for each inductive,
(arity * constructors) (with params)
* (indices * splayed constructor types) (both without params)
* top allowed elimination
*)
val typecheck_inductive : env -> mutual_inductive_entry ->
env
* universes * Univ.Variance.t array option
* Names.Id.t array option option
* Constr.rel_context
* ((inductive_arity * Constr.types array) *
(Constr.rel_context * (Constr.rel_context * Constr.types) array) *
Sorts.family)
array
(* Utility function to compute the actual universe parameters
of a template polymorphic inductive *)
val template_polymorphic_univs :
template_check:bool ->
Univ.ContextSet.t ->
Constr.rel_context ->
Univ.Universe.t ->
Univ.Level.t option list * Univ.LSet.t
|