LINX_OSATTREF linx_attach(LINX *linx, union LINX_SIGNAL **sig, LINX_SPID
spid);
int linx_detach(LINX *linx, LINX_OSATTREF *attref);
linx_attach()
is used to supervise another LINX endpoint. When the other endpoint is closed
or becomes unavailable, an attach signal is sent to the supervising LINX
endpoint linx as a notification. If a signal sig is provided, this signal
will be received when the attach is triggered. If sig is NULL, the default
LINX attach signal with signal number LINX_OS_ATTACH_SIG is received instead.
The linx_attach() call consumes the signal, taking over its ownership,
and sets the sig pointer to LINX_NIL. The signal is consumed if an error
occurs too. If sig is corrupt, abort(3)
is called.
linx_detach() is used to detach from an attached LINX endpoint. It’s an
error to detach from a LINX endpoint more than once or to detach from a
LINX endpoint after the attach signal has been received. It is not an error
to detach if the attach signal is waiting in the receive queue of the LINX
endpoint. To prevent multiple detaches, linx_detach() sets the attref pointer
to LINX_ILLEGAL_ATTREF.
linx is the handle of the LINX endpoint.
spid is the identifier of the LINX endpoint to supervise.
sig is either NULL or a user defined LINX signal.
attref is the LINX_OSATTREF attach reference obtained from linx_attach().
On failure, linx_attach() returns LINX_ILLEGAL_ATTREF and linx_detach() returns -1, and errno is set appropriately.
Server: #include <linx.h> #define CLIENT_DONE_SIG 0x1234 int main (int argc, char *argv[]) { LINX *linx; LINX_SPID client; union LINX_SIGNAL *sig; const LINX_SIGSELECT sel_hunt_sig[] = { 1, LINX_OS_HUNT_SIG }; const LINX_SIGSELECT sel_att_sig [] = { 1, LINX_OS_ATTACH_SIG }; /* Create a LINX endpoint with huntname "attacher" */ linx = linx_open("attacher", NULL, 0); /* Hunt for the client */ linx_hunt(linx, "client", NULL); /* Receive hunt signal */ linx_receive(linx, &sig, sel_hunt_sig); /* Retrive the clients spid */ client = linx_sender(linx, &sig) /* Free the hunt signal */ linx_free_buf(linx, &sig); /* Attach to the client */ linx_attach(linx, client, NULL); /* Create "done" signal */ sig = linx_alloc(linx, sizeof(LINX_SIGSELECT), CLIENT_DONE_SIG); /* Send "done" signal to client */ linx_send(linx, &sig, client); /* Wait for the attach signal */ linx_receive(linx, &sig, sel_att_sig); /* Close the LINX endpoint */ linx_close(linx); return 0; } Client: #include <linx.h> int main (int argc, char *argv[]) { LINX *linx; union LINX_SIGNAL *sig; const LINX_SIGSELECT sel_done_sig[] = { 1, CLIENT_DONE_SIG }; /* Open a LINX endpoint with huntname "client" */ linx = linx_open("client", NULL, 0); /* Wait for server to send "done" signal */ linx_receive(linx, &sig, sel_done_sig); /* Close the LINX endpoint - this will trigger the attach */ linx_close(linx); return 0; }
Copyright (c) 2006-2007, Enea
Software AB All rights reserved.
Redistribution and use in source and binary forms, with or without modification,
are permitted provided that the following conditions are met:
Redistributions of source code must retain the above copyright notice,
this list of conditions and the following disclaimer. Redistributions in
binary form must reproduce the above copyright notice, this list of conditions
and the following disclaimer in the documentation and/or other materials
provided with the distribution. Neither the name of Enea Software AB nor
the names of its contributors may be used to endorse or promote products
derived from this software without specific prior written permission.
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.