forked from rocq-archive/coq-serapi
-
Notifications
You must be signed in to change notification settings - Fork 0
/
ser_context.mli
63 lines (43 loc) · 2.09 KB
/
ser_context.mli
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
(************************************************************************)
(* v * The Coq Proof Assistant / The Coq Development Team *)
(* <O___,, * INRIA - CNRS - LIX - LRI - PPS - Copyright 1999-2016 *)
(* \VV/ **************************************************************)
(* // * This file is distributed under the terms of the *)
(* * GNU Lesser General Public License Version 2.1 *)
(************************************************************************)
(************************************************************************)
(* Coq serialization API/Plugin *)
(* Copyright 2016-2017 MINES ParisTech *)
(* Written by: Emilio J. Gallego Arias *)
(************************************************************************)
(* Status: Very Experimental *)
(************************************************************************)
open Sexplib
type 'a binder_annot = 'a Context.binder_annot
[@@deriving sexp,yojson,hash,compare]
module Rel : sig
module Declaration : sig
type ('c,'t) pt = ('c,'t) Context.Rel.Declaration.pt
[@@deriving sexp,yojson,hash,compare]
end
type ('c, 't) pt = ('c,'t) Context.Rel.pt
[@@deriving sexp,yojson,hash,compare]
end
module Named : sig
module Declaration : sig
type ('c, 't) pt = ('c, 't) Context.Named.Declaration.pt
[@@deriving sexp,yojson,hash,compare]
end
type ('c, 't) pt = ('c, 't) Context.Named.pt
[@@deriving sexp,yojson,hash,compare]
end
module Compacted : sig
module Declaration : sig
type ('c, 't) pt = ('c, 't) Context.Compacted.Declaration.pt
val pt_of_sexp : (Sexp.t -> 'c) -> (Sexp.t -> 't) -> Sexp.t -> ('c,'t) pt
val sexp_of_pt : ('c -> Sexp.t) -> ('t -> Sexp.t) -> ('c,'t) pt -> Sexp.t
end
type ('c, 't) pt = ('c, 't) Context.Compacted.pt
val pt_of_sexp : (Sexp.t -> 'c) -> (Sexp.t -> 't) -> Sexp.t -> ('c,'t) pt
val sexp_of_pt : ('c -> Sexp.t) -> ('t -> Sexp.t) -> ('c,'t) pt -> Sexp.t
end