From 55f376e0acf3a6dea0da68f480c945afa7952abb Mon Sep 17 00:00:00 2001 From: jestin Date: Fri, 27 Sep 2002 17:26:26 +0000 Subject: see TODO for details. Mostly bugfixes. --- src/Ivy.java | 66 +++++++++++++++++++++++++++++++++++++++++++++-------- src/IvyClient.java | 5 +++- src/IvyWatcher.java | 13 ++++++++--- src/Probe.java | 57 ++++++++++++++++++++++++++++++++++----------- 4 files changed, 114 insertions(+), 27 deletions(-) diff --git a/src/Ivy.java b/src/Ivy.java index 15926bc..5e149ec 100755 --- a/src/Ivy.java +++ b/src/Ivy.java @@ -22,7 +22,12 @@ import java.util.*; * * * CHANGELOG: - * 1.0.12: + * 1.2.1: + * - bus.start(null) now starts on DEFAULT_DOMAIN + * - added the getDomains in order to correctly display the domain list + * - checks if the serverThread exists before interrupting it + * - no has unBindMsg(String) + * 1.2.0: * - setSoTimeout is back on the server socket * - added a regression test main() * - clients is now a Hashtable. the deletion now works better @@ -55,7 +60,7 @@ public class Ivy implements Runnable { * the library version, useful for development purposes only, when java is * invoked with -DIVY_DEBUG */ - public static final String libVersion ="1.2.0"; + public static final String libVersion ="1.2.1"; private boolean debug; private static int serial=0; /* an unique ID for each regexp */ @@ -107,6 +112,7 @@ public class Ivy implements Runnable { * */ public void start(String domainbus) throws IvyException { + if (domainbus==null) domainbus=DEFAULT_DOMAIN; try { app = new ServerSocket(0); app.setSoTimeout(TIMEOUTLENGTH); @@ -117,13 +123,10 @@ public class Ivy implements Runnable { traceDebug("lib: "+libVersion+" protocol: "+PROCOCOLVERSION+" TCP service open on port "+applicationPort); watchers = new Vector(); + Domain[] d = parseDomains(domainbus); // readies the rendezvous : an IvyWatcher (thread) per domain bus - StringTokenizer st = new StringTokenizer(domainbus,","); - while ( st.hasMoreTokens()) { - String s = st.nextToken() ; - String domainaddr=IvyWatcher.getDomain(s); - int port=IvyWatcher.getPort(s); - IvyWatcher watcher =new IvyWatcher(this,domainaddr,port); + for (int index=0;indexhttp://www.tls.cena.fr/products/ivy/ * * * Changelog: - * 1.0.12 + * 1.2.1 + * - new -t switch to print the date for each ivy message + * - now displays the correct domain list + * - now has .bind and .unbind commands + * 1.2.0 * - Probe can now send empty strings on keyboard input * - rewritten with a looping thread on stdin to allow a cleaner exit on die * message : not very good @@ -29,12 +31,13 @@ class Probe implements IvyApplicationListener, IvyMessageListener, Runnable { /** * help message for the standalone program */ - public static final String helpCommands = "Available commands:\n.die CLIENTNAME sends a die message\n.bye quits the application\n.quit idem\n.list lists the available clients\n.ping sends a ping request if IVY_PING is enabled"; - public static final String helpmsg = "usage: java fr.dgac.ivy.Probe [options] [regexp]\n\t-b BUS\tspecifies the Ivy bus domain\n\t-n ivyname (default JPROBE)\n\t-q\tquiet, no tty output\n\t-d\tdebug\n\t-h\thelp\n\n\t regexp is a Perl5 compatible regular expression"; + public static final String helpCommands = "Available commands:\n.die CLIENTNAME sends a die message\n.bye quits the application\n.quit idem\n.list lists the available clients\n.ping sends a ping request if IVY_PING is enabled\n.bind REGEXP binds to a regexp at runtime\n.unbind REGEXP unbinds to a regexp at runtime"; + public static final String helpmsg = "usage: java fr.dgac.ivy.Probe [options] [regexp]\n\t-b BUS\tspecifies the Ivy bus domain\n\t-n ivyname (default JPROBE)\n\t-q\tquiet, no tty output\n\t-d\tdebug\n\t-t\ttime stamp each message\n\t-h\thelp\n\n\t regexp is a Perl5 compatible regular expression"; public static void main(String[] args) throws IvyException { - Getopt opt = new Getopt("Probe",args,"n:b:dh"); + Getopt opt = new Getopt("Probe",args,"n:b:dht"); int c; + boolean timestamp=false; String domain=Ivy.getDomain(null); String name="JPROBE"; while ((c = opt.getopt()) != -1) switch (c) { @@ -44,6 +47,9 @@ class Probe implements IvyApplicationListener, IvyMessageListener, Runnable { case 'n': name=opt.getOptarg(); break; + case 't': + timestamp=true; + break; case 'd': System.setProperty("IVY_DEBUG","yes"); break; @@ -52,13 +58,18 @@ class Probe implements IvyApplicationListener, IvyMessageListener, Runnable { System.out.println(helpmsg); System.exit(0); } // getopt - Probe p = new Probe(); + Probe p = new Probe(timestamp); Ivy bus=new Ivy(name,name+" ready",p); for (int i=opt.getOptind();i Sent to " +bus.sendMsg(s)+" peers"); + System.out.println(date()+"-> Sent to " +bus.sendMsg(s)+" peers"); } else if (s.lastIndexOf(".die ")>=0){ String target=s.substring(5); Vector v=bus.getIvyClientsByName(target); @@ -115,6 +128,17 @@ class Probe implements IvyApplicationListener, IvyMessageListener, Runnable { for (int i=0;i=0){ + String regexp=s.substring(8); + if (bus.unBindMsg(regexp)) { + System.out.println("you want to unsubscribe to " + regexp); + } else { + System.out.println("you can't unsubscribe to " + regexp + ", your're not subscribed to it"); + } + } else if (s.lastIndexOf(".bind ")>=0){ + String regexp=s.substring(6); + System.out.println("you want to subscribe to " + regexp); + bus.bindMsg(regexp,this); } else if (s.lastIndexOf(".ping ")>=0){ String target=s.substring(6); Vector v=bus.getIvyClientsByName(target); @@ -131,7 +155,7 @@ class Probe implements IvyApplicationListener, IvyMessageListener, Runnable { Vector v = bus.getIvyClients(); System.out.println(v.size()+" clients on the bus"); for (int i=0;i "+((IvyClient)v.elementAt(i)).getApplicationName()); + System.out.println("-> "+((IvyClient)v.elementAt(i)).getApplicationName()); } } else if ( s.lastIndexOf(".help")>=0) { System.out.println(helpCommands); @@ -139,7 +163,7 @@ class Probe implements IvyApplicationListener, IvyMessageListener, Runnable { System.out.println("this command is not recognized"); System.out.println(helpCommands); } else { - System.out.println("-> Sent to " +bus.sendMsg(s)+" peers"); + System.out.println(date()+"-> Sent to " +bus.sendMsg(s)+" peers"); } } // parseCommand @@ -167,9 +191,16 @@ class Probe implements IvyApplicationListener, IvyMessageListener, Runnable { } public void receive(IvyClient client, String[] args) { - String s=client.getApplicationName() + " sent"; + String s=date()+client.getApplicationName() + " sent"; for (int i=0;i