/usr/lib/ocaml/netplex/netplex_encap.mli is in libocamlnet-ocaml-dev 3.7.3-4.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
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 | (* $Id: netplex_encap.mli 1416 2010-02-16 00:25:07Z gerd $ *)
(** Type-safe marshalling between processes of the same executable *)
(** This is a pragmatic approach to type-safe marshalling. We define
[type encap] as an arbitrary value that carries a type identifier with it.
The type identifier is generated when the functor
{!Netplex_encap.Make_encap} is applied. Every instantiation of this
functor generates a new type identifier.
The idea is then that an [encap] value can be marshalled to another
process using [Marshal], and when it is unwrapped the type identifier
is checked. Unwrapping is only successful when the [unwrap] function
from the same functor instantiation is used as the [wrap]
function.
This module is incompatible with:
- Marshalling to processes running a different executable
- Marshalling to processes that are dynamically loading
modules
- The functor must be instantiated at program initialization time.
Especially this must not happen in [let module] expressions.
Only some of these assumptions can be checked at runtime by this
implementation.
*)
exception Type_mismatch
(** Raised when an encapulated type is tried to be unwrapped by the
wrong encapsulation module
*)
type encap
(** An encapsulated value with a type identifier *)
module type TYPE = sig type t end
(** Just a (monomorphic) type [t] *)
module type ENCAP = sig
type t
val wrap : t -> encap
val unwrap : encap -> t
(** Raises {!Netplex_encap.Type_mismatch} if the value does not fit *)
end
module Make_encap(T:TYPE) : ENCAP with type t = T.t
(** Create an encapsulation module *)
|