package coq-serapi
 sectionYPositions = computeSectionYPositions($el), 10)"
  x-init="setTimeout(() => sectionYPositions = computeSectionYPositions($el), 10)"
  >
  
  
  Serialization library and protocol for machine interaction with the Coq proof assistant
Install
    
    dune-project
 Dependency
Authors
Maintainers
Sources
  
    
      coq-serapi-8.20.0.0.20.0.tbz
    
    
        
    
  
  
  
    
  
  
    
  
        sha256=ead9382f111ea385008fe9037513ff1f738dd90d8e989b8d1a0c9290963d9afe
    
    
  sha512=b29103c2d1eb3cf8a33fa9ddf26b5a6c89e7277cd31256589bcae8a89c37a3de7a3c3e7fe5d376358e874d44dc6c60ab96736cbd1037511ab36705e9f40f0ade
    
    
  doc/src/coq-serapi.serapi_v8_14/serapi_assumptions.ml.html
Source file serapi_assumptions.ml
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 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96(************************************************************************) (* * The Coq Proof Assistant / The Coq Development Team *) (* v * Copyright INRIA, CNRS and contributors *) (* <O___,, * (see version control and CREDITS file for authors & dates) *) (* 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) *) (************************************************************************) (************************************************************************) (* SerAPI: Coq interaction protocol with bidirectional serialization *) (************************************************************************) (* Copyright 2016-2019 MINES ParisTech -- License LGPL 2.1+ *) (* Copyright 2019-2023 Inria -- License LGPL 2.1+ *) (* Written by: Emilio J. Gallego Arias and others *) (************************************************************************) type ax_ctx = (Names.Label.t * Constr.rel_context * Constr.t) list type t = { predicative : bool ; type_in_type : bool ; vars : (Names.Id.t * Constr.t) list ; axioms : (Printer.axiom * Constr.t * ax_ctx) list ; opaque : (Names.Constant.t * Constr.t) list ; trans : (Names.Constant.t * Constr.t) list } let build env ctxmap = let open Printer in let fold t typ accu = let (v, a, o, tr) = accu in match t with | Variable id -> ((id,typ) :: v, a, o, tr) | Axiom (axiom, l) -> (v, (axiom,typ,l) :: a, o, tr) | Opaque kn -> (v, a, (kn,typ) :: o, tr) | Transparent kn -> (v, a, o, (kn,typ) :: tr) in let (vars, axioms, opaque, trans) = ContextObjectMap.fold fold ctxmap ([], [], [], []) in { predicative = not (Environ.is_impredicative_set env) ; type_in_type = Environ.type_in_type env ; vars ; axioms ; opaque ; trans } let print env sigma { predicative; type_in_type; vars; axioms; opaque; trans } = let pr_engament e = match e with | false -> Pp.str "Set is Impredicative" | true -> Pp.str "Set is Predicative" in let pr_var env sigma (id, typ) = Pp.(seq [Names.Id.print id; str " : "; Printer.pr_ltype_env env sigma typ ]) in let pr_constant env sigma (cst, typ) = Pp.(seq [Names.Constant.print cst; str " : "; Printer.pr_ltype_env env sigma typ ]) in let pr_axiom env sigma (ax, typ, lctx) = let pr_ax env sigma typ a = let open Printer in match a with | Constant kn -> Pp.(seq [Names.Constant.print kn; str " : "; Printer.pr_ltype_env env sigma typ]) | Positive m -> Pp.(seq [Printer.pr_inductive env (m,0); str "is positive."]) | Guarded gr -> Pp.(seq [Printer.pr_global gr; str "is positive."]) | TypeInType gr -> Pp.(seq [Printer.pr_global gr; spc (); strbrk "relies on an unsafe hierarchy."]) | UIP m -> Pp.(seq [Printer.pr_inductive env (m,0); spc (); strbrk "relies on UIP."]) in Pp.(seq [ pr_ax env sigma typ ax ; prlist (fun (lbl, ctx, ty) -> str " used in " ++ Names.Label.print lbl ++ str " to prove:" ++ Printer.pr_ltype_env Environ.(push_rel_context ctx env) sigma ty) lctx ]) in Pp.(v 0 (prlist_with_sep (fun _ -> cut ()) (fun x -> x) [ if type_in_type then str "type_in_type is on" else mt () ; pr_engament predicative ; hov 1 (prlist (pr_var env sigma) vars) ; hov 1 (prlist (pr_constant env sigma) opaque) ; hov 1 (prlist (pr_constant env sigma) trans) ; hov 1 (prlist (pr_axiom env sigma) axioms) ]))
 sectionYPositions = computeSectionYPositions($el), 10)"
  x-init="setTimeout(() => sectionYPositions = computeSectionYPositions($el), 10)"
  >