/usr/lib/ocaml/batteries/batInterfaces.mli is in libbatteries-ocaml-dev 2.2-1.
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 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 | (*
* Interfaces - Common interfaces for data structures
* Copyright (C) 2008 David Teller, LIFO, Universite d'Orleans
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 2.1 of the License, or (at your option) any later version,
* with the special exception on linking described in file LICENSE.
*
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
*)
(**
Common signatures for data structures.
*)
(** A signature for data structures which have a
[map : ('a -> 'b) -> ('a t -> 'b t)] operation.
If you create a new data structure, you should make it compatible
with [Mappable].
*)
module type Mappable = sig
type 'a mappable (** The data structure, e.g. ['a List.t] *)
val map : ('a -> 'b) -> ('a mappable -> 'b mappable)
(** [map f e] applies [f] to every element of [e] and returns the corresponding data structure *)
end
module type OrderedType =
sig
type t
val compare : t -> t -> int
(** A total ordering function
This is a two-argument function [f] such that
[f e1 e2] is zero if the values [e1] and [e2] are equal,
[f e1 e2] is strictly negative if [e1] is smaller than [e2],
and [f e1 e2] is strictly positive if [e1] is greater than [e2].
Example: a suitable ordering function is the generic structural
comparison function {!Pervasives.compare}. *)
end
(** Monads are a design pattern which may be used to enforce strong
functional or non-functional constraints on the manipulation of
resources, while remaining in the world of functional programming.
For instance, monads may serve to implement approximations of a
types-and-effects type system, to enforce functional use of arrays
or other mutable data structures, or to enforce the fact that only
files opened for writing may be actually used for writing.
For more information on monads, see
{{:http://enfranchisedmind.com/blog/2007/08/06/a-monad-tutorial-for-ocaml/}
A Monad Tutorial for Ocaml}.
This definition is compatible with the standard syntax extension
for monads. For more information, see
{{:http://www.cas.mcmaster.ca/~carette/pa_monad/} the
documentation of pa_monad}.
@author David Teller
*)
(** Signature for monads *)
module type Monad = sig
(** The type of a monad producing values of type ['a].*)
type 'a m
(** Monadic binding.
[bind m f] executes first [m] then [f], using the
result of [m]. *)
val bind : 'a m -> ('a -> 'b m) -> 'b m
(**Return a value, that is, put a value in the monad.*)
val return: 'a -> 'a m
end
|