diff options
author | jacomi | 1999-03-17 19:11:36 +0000 |
---|---|---|
committer | jacomi | 1999-03-17 19:11:36 +0000 |
commit | 7cfa818995332e8b54fc1831bacdf9c2d131155c (patch) | |
tree | 5cfb9f36352a36f014d54280985e12fac5348e53 /doc | |
parent | 4ebda522e35e16f7e7cc4fe14a9fdfb2d6bcd605 (diff) | |
download | ivy-c-7cfa818995332e8b54fc1831bacdf9c2d131155c.zip ivy-c-7cfa818995332e8b54fc1831bacdf9c2d131155c.tar.gz ivy-c-7cfa818995332e8b54fc1831bacdf9c2d131155c.tar.bz2 ivy-c-7cfa818995332e8b54fc1831bacdf9c2d131155c.tar.xz |
first draft for man pages on ivy-c
Diffstat (limited to 'doc')
-rw-r--r-- | doc/ivy-c.1 | 244 | ||||
-rw-r--r-- | doc/ivy-c.htm | 228 | ||||
-rw-r--r-- | doc/ivyprobe.1 | 16 |
3 files changed, 488 insertions, 0 deletions
diff --git a/doc/ivy-c.1 b/doc/ivy-c.1 new file mode 100644 index 0000000..00472e2 --- /dev/null +++ b/doc/ivy-c.1 @@ -0,0 +1,244 @@ +'\" +'\" Ivy, C interface \- library managing connexions to a software bus +'\" +'\" Copyright (C) 1997-1999 +'\" Centre d'Études de la Navigation Aérienne +'\" +'\" See the file "license.terms" for information on usage and redistribution +'\" of this file, and for a DISCLAIMER OF ALL WARRANTIES. +'\" +'\" +'\" # Start an argument description +.de AP +.ie !"\\$4"" .TP \\$4 +.el \{\ +. ie !"\\$2"" .TP \\n()Cu +. el .TP 15 +.\} +.ie !"\\$3"" \{\ +.ta \\n()Au \\n()Bu +\&\\$1 \\fI\\$2\\fP (\\$3) +.\".b +.\} +.el \{\ +.br +.ie !"\\$2"" \{\ +\&\\$1 \\fI\\$2\\fP +.\} +.el \{\ +\&\\fI\\$1\\fP +.\} +.\} +.. +'\" # define tabbing values for .AP +.de AS +.nr )A 10n +.if !"\\$1"" .nr )A \\w'\\$1'u+3n +.nr )B \\n()Au+15n +.\" +.if !"\\$2"" .nr )B \\w'\\$2'u+\\n()Au+3n +.nr )C \\n()Bu+\\w'(in/out)'u+2n +.. +'\" # BS - start boxed text +'\" # ^y = starting y location +'\" # ^b = 1 +.TH Ivy-c 1 3.0 "Ivy-c Library Functions" +.SH NAME +IvyInit, IvyStart, IvyStop, IvyBindMsg, IvyUnbindMsg, IvyBindDirectMsg, +IvySendMsg, IvySendDirectMsg, IvySendDieMsg, IvySendError, IvyGetApplicationName, +IvyGetApplicationHost, IvyGetApplication, IvyGetApplicationList, +IvyGetApplicationMessages, IvyDefaultApplicationCallback, IvyClasses, +IvyChannelInit, IvyChannelSetUp, IvyMainLoop, IvyChannelClose, +IvyChannelDelete, IvyChannelHandleRead, +IvyChannelHandleExcpt, IvyXtChannelInit, IvyXtChannelSetUp +IvyXtChannelClose, IvyXtHandleChannelRead, IvyXtHandleChannelDelete, +IvyXtChannelAppContext, +.SH SYNOPSIS +useful library functions for communicating through a sofware bus +.nf +.sp +\fBIvyInit(\fIAppName, ready, callback, data, die_callback, die_data\fB)\fR +.sp +void +\fBIvyStart(\fIbus\fB)\fR +.sp +void +\fBIvyStop()\fR +.sp +MsgRcvPtr +\fBIvyBindMsg(\fIcallback, user_data, regexp, ...\fB)\fR +.sp +void +\fBIvyUnbindMsg(\fIid\fB)\fR +.sp +void +\fBIvyBindDirectMsg(\fIcallback, user_data\fB)\fR +.sp +int +\fBIvySendMsg(\fIfmt_message, ...\fB)\fR +.sp +void +\fBIvySendDirectMsg(\fIapp, id, msg\fB)\fR +.sp +void +\fBIvySendDieMsg(\fIapp\fB)\fR +.sp +void +\fBIvySendError(\fIapp, id, fmt, ...\fB)\fR +.sp +char* +\fBIvyGetApplicationName(\fIapp\fB)\fR +.sp +char* +\fBIvyGetApplicationHost(\fIapp\fB)\fR +.sp +char* +\fBIvyGetApplication(\fIname\fB)\fR +.sp +char* +\fBIvyGetApplicationList()\fR +.sp +char** +\fBIvyGetApplicationMessages(\fapp\fB)\fR +.sp +char* +\fBIvyDefaultApplicationCallback(\fIapp, user_data, Event\fB)\fR +char* +\fBIvyClasses(\fIargc, argv\fB)\fR +.sp +void +\fBIvyChannelInit(\fIvoid\fB)\fR +.sp +Channel +\fBIvyChannelSetUp(\fIfd, data, handle_delete, handle_read\fB)\fR +.sp +void +\fBIvyMainLoop(\fIhook\fB)\fR +.sp +void +\fBIvyChannelClose(\fIchannel\fB)\fR +.sp +static void +\fBIvyChannelDelete(\fIchannel\fB)\fR +.sp +static void +\fBIvyChannelHandleRead(\fIcurrent\fB)\fR +.sp +static void +\fBIvyChannelHandleExcpt(\fIcurrent\fB)\fR +.sp +static void +\fBIvyXtChannelInit(\fIvoid\fB)\fR +.sp +static void +\fBIvyXtChannelSetUp(\fIfd, data, handle_delete, handle_read\fB)\fR +.sp +void +\fBIvyXtChannelClose(\fIchannel\fB)\fR +.sp +static void +\fBIvyXtHandleChannelRead(\fIclosure, source, id\fB)\fR +.sp +static void +\fBIvyXtHandleChannelDelete(\fIclosure, source, id\fB)\fR +.sp +void +\fBIvyChannelAppContext(\fIcntx\fB)\fR +.SH ARGUMENTS +.SH +\fBIvyInit\fR: +Initialisation of a connection +.sp +.AS "MaxSize" die_callback +.AP const_char *AppName in +Application Name +.AP const_char *ready in +Ready Message (can be NULL) +.AP IvyApplicationCallback callback in +Callback to be called on a connexion/deconnexion of an application +.AP void *data in +user data +.AP IvyDieCallback die_callback in +last change callback before die +.AP void *die_data in +user data +.SH +\fBIvyStart\fR: +Initialisation of TCP/UPD port and sending of a broadcast handshake on every network +.AP const_char *bus in +Bus (format : network list followed by broadcast port) example : +123.231,123.123:2000 or 123.231 or :2000 +If no argument specified, check the environment variable \fBIVYBUS\fR, +else use the default value : 127.255.255.255:2010 +.SH +\fBIvyBindMsg\fR: +Message binding +.AP MsgCallback callback in +.AP void *user_data in +.AP const_char *regexp in +.AP MsgRcvPtr id out +.SH +\fBIvyUnbindMsg\fR: +Message unbinding +.AP MsgRcvPtr id in +.SH +\fBIvyChannelSetUp\fR: + +.AP HANDLE fd in +.AP void *data in +.AP ChannelHandleDelete handle_delete in +.AP ChannelHandleRead handle_read in +.AP Channel out out +.VE +.BE +.SH DESCRIPTION +.PP +These procedures provide facilities for connecting applications on a +software bus and managing messages exchanges among them. + +.SH EXAMPLES +Simple C code: +.nf + +.DS + +#include "ivyloop.h" +#include "ivysocket.h" +#include "ivy.h" + + int main (int argc, char* argv[]){ + IvyInit ("IVYPROBE", + bport, + "IVYPROBE READY", + ApplicationCallback, + NULL, + NULL, + NULL) + IvyChannelSetUp(0, NULL, NULL, HandleStdin); + IvyStart (domains); + IvyMainLoop(0) +}; +.DE + +.SH FILES +.I /usr/include/ivy.h +.I /usr/include/ivyloop.h +.I /usr/include/ivysocket.h +.SH ENVIRONMENT +.I IVYDOMAINS +.I IVYBUS +.SH DIAGNOSTICS +error messages displayed +.SH BUGS +none ! +.SH AUTHORS +Francois-Regis Colin <fcolin@cenatoulouse.dgac.fr> +Stephane Chatty <chatty@cenatoulouse.dgac.fr> +.SH SEE ALSO +ivyprobe (1) +.sp +For further details, please refer to the Ivy html page at http://www.cenatls.cena.dgac.fr/pii/produits/Ivy.html +.SH NOTES +In case of any comment or bug report on this library, please contact +fcolin@cenatoulouse.dgac.fr, chatty@cenatoulouse.dgac.fr, jacomi@cenatoulouse.dgac.fr + diff --git a/doc/ivy-c.htm b/doc/ivy-c.htm new file mode 100644 index 0000000..5521560 --- /dev/null +++ b/doc/ivy-c.htm @@ -0,0 +1,228 @@ +<HTML> +<HEAD> +</HEAD> +<BODY> +<!-- Ivy, C interface \- library managing connexions to a software bus--> +<!-- Copyright (C) 1997-1999--> +<!-- Centre d'Études de la Navigation Aérienne--> +<!-- See the file "license.terms" for information on usage and redistribution--> +<!-- of this file, and for a DISCLAIMER OF ALL WARRANTIES.--> +<!-- --> +<!-- --> +<!-- # Start an argument description--> +<!-- # define tabbing values for .AP--> +<!-- # BS - start boxed text--> +<!-- # ^y = starting y location--> +<!-- # ^b = 1--> +<H2><A NAME=NAME>NAME</A></H2> +IvyInit, IvyStart, IvyStop, IvyBindMsg, IvyUnbindMsg, IvyBindDirectMsg, +IvySendMsg, IvySendDirectMsg, IvySendDieMsg, IvySendError, IvyGetApplicationName, +IvyGetApplicationHost, IvyGetApplication, IvyGetApplicationList, +IvyGetApplicationMessages, IvyDefaultApplicationCallback, IvyClasses, +IvyChannelInit, IvyChannelSetUp, IvyMainLoop, IvyChannelClose, +IvyChannelDelete, IvyChannelHandleRead, +IvyChannelHandleExcpt, IvyXtChannelInit, IvyXtChannelSetUp +IvyXtChannelClose, IvyXtHandleChannelRead, IvyXtHandleChannelDelete, +IvyXtChannelAppContext, +<H2><A NAME=SYNOPSIS>SYNOPSIS</A></H2> +useful library functions for communicating through a sofware bus +<BR> +<P> +<B>IvyInit(</B><I>AppName, ready, callback, data, die_callback, die_data</I><B>)</B> +<P> +void +<B>IvyStart(</B><I>bus</I><B>)</B> +<P> +void +<B>IvyStop()</B> +<P> +MsgRcvPtr +<B>IvyBindMsg(</B><I>callback, user_data, regexp, ...</I><B>)</B> +<P> +void +<B>IvyUnbindMsg(</B><I>id</I><B>)</B> +<P> +void +<B>IvyBindDirectMsg(</B><I>callback, user_data</I><B>)</B> +<P> +int +<B>IvySendMsg(</B><I>fmt_message, ...</I><B>)</B> +<P> +void +<B>IvySendDirectMsg(</B><I>app, id, msg</I><B>)</B> +<P> +void +<B>IvySendDieMsg(</B><I>app</I><B>)</B> +<P> +void +<B>IvySendError(</B><I>app, id, fmt, ...</I><B>)</B> +<P> +char* +<B>IvyGetApplicationName(</B><I>app</I><B>)</B> +<P> +char* +<B>IvyGetApplicationHost(</B><I>app</I><B>)</B> +<P> +char* +<B>IvyGetApplication(</B><I>name</I><B>)</B> +<P> +char* +<B>IvyGetApplicationList()</B> +<P> +char** +<B>IvyGetApplicationMessages(</B>\fapp<B>)</B> +<P> +char* +<B>IvyDefaultApplicationCallback(</B><I>app, user_data, Event</I><B>)</B> +char* +<B>IvyClasses(</B><I>argc, argv</I><B>)</B> +<P> +void +<B>IvyChannelInit(</B><I>void</I><B>)</B> +<P> +Channel +<B>IvyChannelSetUp(</B><I>fd, data, handle_delete, handle_read</I><B>)</B> +<P> +void +<B>IvyMainLoop(</B><I>hook</I><B>)</B> +<P> +void +<B>IvyChannelClose(</B><I>channel</I><B>)</B> +<P> +static void +<B>IvyChannelDelete(</B><I>channel</I><B>)</B> +<P> +static void +<B>IvyChannelHandleRead(</B><I>current</I><B>)</B> +<P> +static void +<B>IvyChannelHandleExcpt(</B><I>current</I><B>)</B> +<P> +static void +<B>IvyXtChannelInit(</B><I>void</I><B>)</B> +<P> +static void +<B>IvyXtChannelSetUp(</B><I>fd, data, handle_delete, handle_read</I><B>)</B> +<P> +void +<B>IvyXtChannelClose(</B><I>channel</I><B>)</B> +<P> +static void +<B>IvyXtHandleChannelRead(</B><I>closure, source, id</I><B>)</B> +<P> +static void +<B>IvyXtHandleChannelDelete(</B><I>closure, source, id</I><B>)</B> +<P> +void +<B>IvyChannelAppContext(</B><I>cntx</I><B>)</B> +<H2><A NAME=ARGUMENTS>ARGUMENTS</A></H2> +<H2><A NAME=Section0></A></H2> +<B>IvyInit</B>: +Initialisation of a connection +<P> +<DL> +<DT><CODE>const_char *AppName</CODE> +(in) <DD>Application Name +<DT><CODE>const_char *ready</CODE> +(in) <DD>Ready Message (can be NULL) +<DT><CODE>IvyApplicationCallback callback</CODE> +(in) <DD>Callback to be called on a connexion/deconnexion of an application +<DT><CODE>void *data</CODE> +(in) <DD>user data +<DT><CODE>IvyDieCallback die_callback</CODE> +(in) <DD>last change callback before die +<DT><CODE>void *die_data</CODE> +(in) <DD>user data +</DL> +<H2><A NAME=Section0></A></H2> +<B>IvyStart</B>: +Initialisation of TCP/UPD port and sending of a broadcast handshake on every network +<DL> +<DT><CODE>const_char *bus</CODE> +(in) <DD>Bus (format : network list followed by broadcast port) example : +123.231,123.123:2000 or 123.231 or :2000 +If no argument specified, check the environment variable <B>IVYBUS</B>, +else use the default value : 127.255.255.255:2010 +</DL> +<H2><A NAME=Section0></A></H2> +<B>IvyBindMsg</B>: +Message binding +<DL> +<DT><CODE>MsgCallback callback</CODE> +(in) <DD><DT><CODE>void *user_data</CODE> +(in) <DD><DT><CODE>const_char *regexp</CODE> +(in) <DD><DT><CODE>MsgRcvPtr id</CODE> +(out) <DD></DL> +<H2><A NAME=Section0></A></H2> +<B>IvyUnbindMsg</B>: +Message unbinding +<DL> +<DT><CODE>MsgRcvPtr id</CODE> +(in) <DD></DL> +<H2><A NAME=Section0></A></H2> +<B>IvyChannelSetUp</B>: + +<DL> +<DT><CODE>HANDLE fd</CODE> +(in) <DD><DT><CODE>void *data</CODE> +(in) <DD><DT><CODE>ChannelHandleDelete handle_delete</CODE> +(in) <DD><DT><CODE>ChannelHandleRead handle_read</CODE> +(in) <DD><DT><CODE>Channel out</CODE> +(out) <DD></DL> +<HR> +<BR> +<H2><A NAME=DESCRIPTION>DESCRIPTION</A></H2> +<P> +These procedures provide facilities for connecting applications on a +software bus and managing messages exchanges among them. + +<H2><A NAME=EXAMPLES>EXAMPLES</A></H2> +Simple C code: +<BR> + +<BR> +<PRE> + +#include "ivyloop.h" +#include "ivysocket.h" +#include "ivy.h" + + int main (int argc, char* argv[]){ + IvyInit ("IVYPROBE", + bport, + "IVYPROBE READY", + ApplicationCallback, + NULL, + NULL, + NULL) + IvyChannelSetUp(0, NULL, NULL, HandleStdin); + IvyStart (domains); + IvyMainLoop(0) +}; +<BR> +</PRE> + +<H2><A NAME=FILES>FILES</A></H2> +<I>/usr/include/ivy.h</I> +<I>/usr/include/ivyloop.h</I> +<I>/usr/include/ivysocket.h</I> +<H2><A NAME=ENVIRONMENT>ENVIRONMENT</A></H2> +<I>IVYDOMAINS</I> +<I>IVYBUS</I> +<H2><A NAME=DIAGNOSTICS>DIAGNOSTICS</A></H2> +error messages displayed +<H2><A NAME=BUGS>BUGS</A></H2> +none ! +<H2><A NAME=AUTHORS>AUTHORS</A></H2> +Francois-Regis Colin <fcolin@cenatoulouse.dgac.fr> +Stephane Chatty <chatty@cenatoulouse.dgac.fr> +<H2><A NAME=Section1>SEE ALSO</A></H2> +ivyprobe (1) +<P> +For further details, please refer to the Ivy html page at http://www.cenatls.cena.dgac.fr/pii/produits/Ivy.html +<H2><A NAME=NOTES>NOTES</A></H2> +In case of any comment or bug report on this library, please contact +fcolin@cenatoulouse.dgac.fr, chatty@cenatoulouse.dgac.fr, jacomi@cenatoulouse.dgac.fr + +</BODY> +</HTML> diff --git a/doc/ivyprobe.1 b/doc/ivyprobe.1 new file mode 100644 index 0000000..0f7541f --- /dev/null +++ b/doc/ivyprobe.1 @@ -0,0 +1,16 @@ +.TH IVYPROBE 1 1/29/99 +.SH NAME +ivyprobe, simple program for probing connections on a given port number for ivy software bus +.SH SYNOPSIS +.B ivyprobe [options] [regexp...] +.SH DESCRIPTION +ivyprobe gives the list of applications connected to a given bus port number, receives messages subscribed to (regexp format), and sends messages on the bus. +.SH OPTIONS +.TP +.I "\-b PORT-NUMBER(1-32000)(not 2049)" +The default port number is 2010. +.TP +.I "\-domain NETWORK-ADDRESS" +The default network address is 127.255.255.255 +H SEE ALSO +.IR ivy-c (1) |