Provided by: erlang-manpages_16.b.3-dfsg-1ubuntu2.2_all bug

NAME

       ic_c_protocol - IC C Protocol Functions

DESCRIPTION

       This manual page lists some of the functions of the IC C runtime library that are used internally for the
       IC protocol.

       The  listed functions are used internally by generated C client and server code. They are documented here
       for the advanced user that want to replace the default protocol (Erlang distribution + gen_server) by his
       own protocol, For each set of client or sever functions below with prefix oe, the user has  to  implement
       his  own  set  of  functions,  the  names of which are obtained by replacing the oe prefix by Prefix. The
       Prefix has to be set with the option {user_protocol, Prefix} at compile time.

       The following terminology is used (reflected in names of functions): a notification  is  a  message  send
       from client to server, without any reply back (i.e. a oneway operation); a request is a message sent from
       client to server, and where a reply message is sent back from the server to the client.

       In  order  to understand how the functions work and what they do the user must study their implementation
       in the IC C library (source file is ic.c), and also consider how they are used in the C code of  ordinary
       generated client stubs or server skeletons.

CLIENT PROTOCOL FUNCTIONS

       The following functions are used internally by generated C client code.

EXPORTS

       int oe_prepare_notification_encoding(CORBA_Environment *env)

              The  result  of  this  function  is  the  beginning of a binary of in external format of the tuple
              {'$gen_cast', X} where X is not yet filled in.

              In generated client code this function is the first to be called in the encoding function for each
              oneway operation.

       int oe_send_notification(CORBA_Environment *env)
       int oe_send_notification_tmo(CORBA_Environment *env,  unsigned int send_ms)

              Sends a client notification to  a  server  according  to  the  Erlang  distribution  +  gen_server
              protocol.

              The send_ms parameter specified a timeout in milliseconds.

       int oe_prepare_request_encoding(CORBA_Environment *env)

              The  result  of  this  function  is  the beginning of a binary in the external format of the tuple
              {'$gen_call', {Pid, Ref}, X} where X is not yet filled in.

              In generated client code this function is the first to be called in the encoding function for each
              twoway operation.

       int oe_send_request_and_receive_reply(CORBA_Environment *env)
       int oe_send_request_and_receive_reply_tmo(CORBA_Environment *env,  unsigned  int  send_ms,  unsigned  int
       recv_ms)

              Sends  a  client  request and receives the reply according to the Erlang distribution + gen_server
              protocol. This function calls the  oe_prepare_reply_decoding  function  in  order  to  obtain  the
              gen_server reply.

              send_ms and recv_ms specify timeouts for send and receive, respectively, in milliseconds.

       int oe_prepare_reply_decoding(CORBA_Environment *env)

              Decodes  the  binary version of the tuple {Ref, X}, where X is to be decoded later by the specific
              client decoding function.

SERVER PROTOCOL FUNCTIONS

       The following functions are used internally by generated C server code.

EXPORTS

       int oe_prepare_request_decoding(CORBA_Environment *env)

              Decodes the binary version of the tuple {'$gen_cast', Op} (Op an atom), or the tuple {'$gen_cast',
              {Op, X}}, where Op is the operation name, and where X is to  be  decoded  later  by  the  specific
              operation decoding function; or

              decodes  the  binary version of the tuple {'$gen_call', {Pid, Ref}, Op} (Op an atom), or the tuple
              {'$gen_call', {Pid, Ref}, {Op, X}}, where Op> is the operation name, and X is to be  decode  later
              by the specific operation decoding function.

       int oe_prepare_reply_encoding(CORBA_Environment *env)

              Encodes  the  beginning of the binary version of the tuple {{Ref,X}, where X is to be filled in by
              the specific server encoding function.

SEE ALSO

       ic(3erl), ic_clib(3erl), IC Protocol

Ericsson AB                                         ic 4.3.4                                 ic_c_protocol(3erl)