forked from ocaml/ocaml
-
Notifications
You must be signed in to change notification settings - Fork 0
/
typedecl_variance.mli
63 lines (52 loc) · 2.41 KB
/
typedecl_variance.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
(**************************************************************************)
(* *)
(* OCaml *)
(* *)
(* Gabriel Scherer, projet Parsifal, INRIA Saclay *)
(* Rodolphe Lepigre, projet Deducteam, INRIA Saclay *)
(* *)
(* Copyright 2018 Institut National de Recherche en Informatique et *)
(* en Automatique. *)
(* *)
(* All rights reserved. This file is distributed under the terms of *)
(* the GNU Lesser General Public License version 2.1, with the *)
(* special exception on linking described in the file LICENSE. *)
(* *)
(**************************************************************************)
open Types
open Typedecl_properties
type surface_variance = bool * bool * bool
val variance_of_params :
(Parsetree.core_type * (Asttypes.variance * Asttypes.injectivity)) list ->
surface_variance list
val variance_of_sdecl :
Parsetree.type_declaration -> surface_variance list
type prop = Variance.t list
type req = surface_variance list
val property : (Variance.t list, req) property
type variance_error =
| Variance_not_satisfied of int
| No_variable
| Variance_not_reflected
| Variance_not_deducible
type error =
| Bad_variance of variance_error * surface_variance * surface_variance
| Varying_anonymous
exception Error of Location.t * error
val check_variance_extension :
Env.t -> type_declaration ->
Typedtree.extension_constructor -> req * Location.t -> unit
val compute_decl :
Env.t -> check:bool -> type_declaration -> req -> prop
val update_decls :
Env.t -> Parsetree.type_declaration list ->
(Ident.t * type_declaration) list ->
(Ident.t * type_declaration) list
val update_class_decls :
Env.t ->
(Ident.t * Typedecl_properties.decl *
Types.class_declaration * Types.class_type_declaration *
'a Typedtree.class_infos) list ->
(Typedecl_properties.decl *
Types.class_declaration * Types.class_type_declaration) list
(* FIXME: improve this horrible interface *)