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
|
(**************************************************************************)
(* *)
(* OCaml *)
(* *)
(* Pierre Chambart, OCamlPro *)
(* Mark Shinwell and Leo White, Jane Street Europe *)
(* *)
(* Copyright 2013--2016 OCamlPro SAS *)
(* Copyright 2014--2016 Jane Street Group LLC *)
(* *)
(* 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. *)
(* *)
(**************************************************************************)
[@@@ocaml.warning "+a-4-9-30-40-41-42"]
(** [Parameter.t] carries a unique [Variable.t] used as function parameter.
It can also carry annotations about the usage of the variable. *)
type t
type parameter = t
(** Make a parameter from a variable with default attributes *)
val wrap : Variable.t -> t
val var : t -> Variable.t
(** Rename the inner variable of the parameter *)
val rename
: ?current_compilation_unit:Compilation_unit.t
-> t
-> t
val map_var : (Variable.t -> Variable.t) -> t -> t
module T : Identifiable.Thing with type t = t
module Set : sig
include Identifiable.Set with module T := T
val vars : parameter list -> Variable.Set.t
end
include Identifiable.S with type t := t
and module T := T
and module Set := Set
module List : sig
(** extract variables from a list of parameters, preserving the order *)
val vars : t list -> Variable.t list
end
|