class type multiplex_controller =object..end
multiplex_controller is a quite low-level device to abstract
 bidirectional socket connections. It is independent of any real
 device.
 There can be a reader, a writer (or both), or alternatively,
 the shutdown process may be in progress. One cannot have more than
 one reader and more than more writer.
method alive : boolmethod mem_supported : boolstart_mem_reading and start_mem_writing are possiblemethod event_system : Unixqueue.event_systemmethod tls_session_props : Nettls_support.tls_session_props optionmethod tls_session : (string * string) optionmethod tls_stashed_endpoint : unit -> exnmethod reading : boolmethod start_reading : ?peek:(unit -> unit) ->
       when_done:(exn option -> int -> unit) -> string -> int -> int -> unitwhen_done callback is invoked. The int is the number of read
 bytes. It is 0 if an error occurred which is indicated by the
 exception. The exception End_of_file is used when the end of the
 data stream is reached. The exception Cancelled indicates that
 reading has been cancelled in the meantime.
 This starts one-time read job only, i.e. it is not restarted
 after when_done has been invoked.
It is an error to start reading several times.
 The function peek is called immediately before data is read in
 from the underlying communication channel.
 For getting an engine-based version of start_reading, use
 a signal_engine:
 
 
    let (e, signal) = signal_engine esys in
    mplex # start_reading ~when_done:(fun xo n -> signal (xo,n)) ...
 e will transition to `Done(x0,n) when the read is done.method start_mem_reading : ?peek:(unit -> unit) ->
       when_done:(exn option -> int -> unit) ->
       Netsys_mem.memory -> int -> int -> unitstart_reading, but puts the data into a memory buffer.
        There is an optimization for the case that the descriptor is a
        connected socket, or supports Unix.read. If this is not possible
        the method raises Mem_not_supported.method cancel_reading : unit -> unitwhen_done callback is invoked with the
 number of bytes read so far (which may be 0) and the exception
 Cancelled.
 It is no error if there is no reader.
method writing : boolmethod start_writing : when_done:(exn option -> int -> unit) -> string -> int -> int -> unitwhen_done callback is invoked. The int is the number of written
 bytes. It is 0 if an error occurred which is indicated by the
 exception. The exception Cancelled indicates that
 writing has been cancelled in the meantime.
 This starts one-time write job only, i.e. it is not restarted
 after when_done has been invoked.
It is an error to start writing several times.
 See the comment for start_reading for how to get an engine-based
 version of this method.
method start_mem_writing : when_done:(exn option -> int -> unit) ->
       Netsys_mem.memory -> int -> int -> unitstart_writing, but takes the data from a memory buffer.
        There is an optimization for the case that the descriptor is a
        connected socket, or supports Unix.write. If this is not possible
        the method raises Mem_not_supported.method supports_half_open_connection : boolmethod start_writing_eof : when_done:(exn option -> unit) -> unit -> unitwhen_done callback is invoked. The exception Cancelled indicates
 that writing has been cancelled in the meantime.
 This starts one-time write job only, i.e. it is not restarted
 after when_done has been invoked.
It is an error to start writing several times. It is an error to write EOF when the socket does not support half-open connections.
 See the comment for start_reading for how to get an engine-based
 version of this method.
method cancel_writing : unit -> unitwhen_done callback is invoked with the
 number of bytes read so far (which may be 0) and the exception
 Canelled.
 It is no error if there is no writer.
method read_eof : boolmethod wrote_eof : boolmethod shutting_down : boolmethod start_shutting_down : ?linger:float -> when_done:(exn option -> unit) -> unit -> unitwhen_done callback is invoked. The exception
 indicates whether an error happened. Cancelled means that the
 shutdown operation has been cancelled in the meantime.
 The underlying file descriptor (if any) is not closed. A shutdown
 is only a protocol handshake. After a shutdown, both read_eof
 and wrote_eof are true. Call inactivate to close the descriptor.
 Optionally, one can linger for a certain period of time.
 It is only lingered when the EOF was written before the EOF 
 is seen on input.
 Defaults to linger 60.0. Set to 0 to turn off.
 See the comment for start_reading for how to get an engine-based
 version of this method.
method cancel_shutting_down : unit -> unitwhen_done callback is invoked with
 the exception Cancelled.
 It is no error if no shutdown is in progress.
method inactivate : unit -> unit