Module JoinHelper

module JoinHelper: sig .. end
Helper functions for client and server initialization.

type error = 
| Magic (*Magic number mismatch*)
| Connect (*Connection cannot be established*)
Error report

exception Error of (error * string)
error, message

Fork utilities

type fork_args = 
| No_argument (*No argument is passed to client.*)
| Same_arguments of string array (*All clients will reveive the same arguments.*)
| Argument_generator of (int -> string array) (*The function will be called repeatedly to compute the arguments passed to the various clients.*)
Type of arguments passed to forked clients.
val filter_clients : string array -> string array
filter_clients argv returns a new array identical to the passed one, except that it contains neither the "-clients" switches, nor their arguments.
val do_forks : string -> fork_args -> int -> int list
do_forks prog args n does n forks (none if n is negative), using prog as the program name, and passing args to the forked programs. Returns the pid list of the forked programs.

In case fork_args is Argument_generator g, the calls of g will be g 0, g 1,..., g (n-1).


Configuration

type configuration = {
   mutable host : string; (*Hostname of server.*)
   mutable port : int; (*Listening port of server.*)
   mutable clients : int; (*Number of clients to fork.*)
   mutable forked_program : string; (*Name of client to fork.*)
   mutable fork_args : fork_args; (*Arguments passed to forked clients.*)
   mutable magic_id : string; (*Identifier of magic value.*)
   mutable magic_value : string; (*Magic value.*)
}
Type of configuration for either client or server.
val default_configuration : unit -> configuration
default_configuration () returns a configuration with default values.

These values are:


val make_commandline : configuration -> (Arg.key * Arg.spec * Arg.doc) list
make_configuration cfg returns a list of argument descriptors that will update the configuration cfg when parsed through Arg.parse (or equivalent).

The current version defines the following command line options:

By convention, if cfg.clients is negative, command line options -clients and -forked-program are omitted.
See also Arg.parse.

Client-related functions

type 'a lookup_function = Join.Ns.t -> string -> 'a 
Type of functions accessing a name service to retrieve the value associated with a name.
val lookup_once : 'a lookup_function
A lookup function that tries to retrieve the value only once, raising Not_found if value is not present and Join.Exit if remote name service is down (alias for Join.Ns.lookup).
val lookup_times : int -> float -> 'a lookup_function
lookup_times n w builds a lookup function that tries up to n times to retrieve the value, waiting w seconds between two attempts. Will try indefinitely if n <= 0.
type at_fail_chan = unit Join.chan 
Type of channels receiving () on failure of a site.
val do_at_fail : (unit -> unit) -> at_fail_chan
do_at_fail f builds a channel that calls f upon failure. Exceptions raised by the function are silently ignored.
val do_nothing_at_fail : at_fail_chan
A channel that does noting upon failure.
val exit_at_fail_with_code : int -> at_fail_chan
exit_at_fail_with_code c builds a channel that terminates the current process with code c upon failure.
val exit_at_fail : at_fail_chan
Bare alias for exit_at_fail_with_code 0.
val check_magic : Join.Ns.t -> configuration -> unit
Ensures that client and server have the same magic number, raising Error (Magic,...) if not.
val connect : configuration -> Join.Site.t * Join.Ns.t
connect cfg connect as a client to the server referenced by cfg. Also ensures that client and server have the same magic number. Raises Error (Connect,...) or Error (Magic,...) when connection cannot be established or in case of magic number mismatch.
val init_client : ?at_fail:at_fail_chan ->
configuration -> Join.Ns.t * int list
init_client ~at_fail cfg initializes a client by connecting it to the server referenced by cfg, forking clients, and registering the at_fail channel to act as a guard on server failure (cf. Join.Site.at_fail) with a default of do_nothing_at_fail. Raises Error (Connect,...) or Error (Magic,...) when connection cannot be established or in case of magic number mismatch.

Returns the name service of the server, and the list of the client pids.

val init_client_with_lookup : ?at_fail:at_fail_chan ->
?lookup:'a lookup_function ->
configuration -> string -> Join.Ns.t * int list * 'a
init_client_with_lookup ~at_fail ~lookup cfg name behaves as init_client, additionally looking up for name using lookup (defaulting to lookup_times ~-1 1.0) on the returned server name service.

Returns both the name service and the value associated with name.


Server-related functions

val listen : configuration -> unit
listen cfg initializes a server listening for connections and registers the magic value.
val init_server : configuration -> Join.Ns.t * int list
init_server cfg initializes a server listening for connections, registers the magic value, and forks clients. Returns both the local name service, and the list of the client pids.
val init_server_with_register : configuration -> string -> 'a -> Join.Ns.t * int list
init_server_with_register cfg name value executes init_server cfg and uses the returned name service to register value as name. Returns both the local name service, and the list of the client pids.

Miscellaneous functions

val wait_forever : unit -> 'a
Just waits forever; useful to guarantee that code will not exit prematurely.