module Netplex_kit:sig..end
class type virtual v_processor =object..end
processor, but the methods process and supported_ptypes
 are flagged as virtual
class empty_processor_hooks :unit ->Netplex_types.processor_hooks
class processor_hooks_delegation :Netplex_types.processor_hooks ->Netplex_types.processor_hooks
class virtual processor_base :Netplex_types.processor_hooks ->v_processor
class protocol_switch_processor :(string * Netplex_types.processor) list ->Netplex_types.processor
(proto_name, proto_proc).
class protocol_switch_factory :string -> (string * Netplex_types.processor_factory) list ->Netplex_types.processor_factory
protocol_switch_factory name merge_list: Merges the factories
      in merge_list to a single factory.
val add_helper_service : Netplex_types.controller -> string -> Netplex_types.processor_hooks -> unitadd_helper_service ctrl name hooks: Adds a helper service name to
      the controller
      ctrl. The helper service does not have any externally
      accessible socket, but starts a single regular container that looks
      like any other container. Whatever needs to be initialized must be
      done in the pre_start_hook or the post_start_hook.
      This function must be called in controller context, for example
      in the late_initializer of Netplex_main.startup, but it can
      also be started later.
      For an example, look at examples/netplex/helper_container.ml in
      the distributed source tarball.
      For multi-threaded programs, Netplex_cenv.run_in_controller_context
      is the required companion function to start helper threads at any
      time. Multi-processing programs do not have such an easy way to 
      add helpers. They should it at program startup time.
      Known bug. The the helper component will be in "starting" state as 
      long as the post_start_hook runs.
val create_protocol : ?lstn_backlog:int ->
       ?lstn_reuseaddr:bool ->
       ?so_keepalive:bool ->
       ?tcp_nodelay:bool ->
       ?configure_slave_socket:(Unix.file_descr -> unit) ->
       string -> Netplex_types.extended_address array -> Netplex_types.protocolcreate_protocol name addresses: Creates a protocol object
      from the passed argumentsval create_socket_service_config : ?startup_timeout:float ->
       ?change_user_to:int * int ->
       ?gc_when_idle:bool ->
       ?conn_limit:int ->
       string ->
       Netplex_types.protocol list ->
       Netplex_types.controller_config -> Netplex_types.socket_service_configcreate_socket_service_config name protos ctrl_conf: Creates a
      socket_service_config object from the passed arguments