From: jprocter Date: Tue, 27 Mar 2012 14:55:16 +0000 (+0100) Subject: (JAL-976) - consistent ordering of services according to server URLs and debugging... X-Git-Tag: Jalview_2_9~534^2~4 X-Git-Url: http://source.jalview.org/gitweb/?a=commitdiff_plain;h=0bfc20cd41e038f203443ffd1245d469fdb95c68;p=jalview.git (JAL-976) - consistent ordering of services according to server URLs and debugging race conditions and menu generation --- diff --git a/src/jalview/ws/jws2/Jws2Discoverer.java b/src/jalview/ws/jws2/Jws2Discoverer.java index 1c912d8..afeb53a 100644 --- a/src/jalview/ws/jws2/Jws2Discoverer.java +++ b/src/jalview/ws/jws2/Jws2Discoverer.java @@ -44,6 +44,7 @@ import jalview.gui.AlignFrame; import jalview.gui.Desktop; import jalview.gui.JalviewChangeSupport; import jalview.gui.JvSwingUtils; +import jalview.util.jarInputStreamProvider; import jalview.ws.WSMenuEntryProviderI; import jalview.ws.jws2.jabaws2.Jws2Instance; import compbio.data.msa.JABAService; @@ -132,6 +133,7 @@ public class Jws2Discoverer implements Runnable, WSMenuEntryProviderI Cache.log.debug("Old discovery thread has finished."); } running = true; + changeSupport.firePropertyChange("services", services, new Vector()); oldthread = Thread.currentThread(); try { @@ -158,17 +160,28 @@ public class Jws2Discoverer implements Runnable, WSMenuEntryProviderI { invalidServiceUrls.removeAllElements(); } + ArrayList svctypes=new ArrayList(); List qrys = new ArrayList(); for (final String jwsservers : getServiceUrls()) { JabaWsServerQuery squery = new JabaWsServerQuery(this, jwsservers); + if (svctypes.size()==0) + { + // TODO: remove this ugly hack to get Canonical JABA service ordering for all possible services + for (Services sv:squery.JABAWS2SERVERS) + { + svctypes.add(sv.toString()); + } + + } qrys.add(squery); new Thread(squery).start(); } - boolean finished = false; + boolean finished = true; do { + finished=true; try { Thread.sleep(100); @@ -178,7 +191,7 @@ public class Jws2Discoverer implements Runnable, WSMenuEntryProviderI ; for (JabaWsServerQuery squery : qrys) { - finished |= !squery.isRunning(); + finished = finished && !squery.isRunning(); } if (aborted) { @@ -190,12 +203,32 @@ public class Jws2Discoverer implements Runnable, WSMenuEntryProviderI } } } while (!aborted && !finished); - oldthread = null; - running = false; if (!aborted) { - changeSupport.firePropertyChange("services", new Vector(), services); + // resort services according to order found in jabaws service list + // also ensure servics for each host are ordered in same way. + + if (services!=null && services.size()>0) + { + Jws2Instance[] svcs=new Jws2Instance[services.size()]; + int[] spos=new int[services.size()]; + int ipos=0; + Vector svcUrls = getServiceUrls(); + for (Jws2Instance svc:services) + { + svcs[ipos]=svc; + spos[ipos++]=1000*svcUrls.indexOf(svc.getHost()) + 1+svctypes.indexOf(svc.serviceType); + } + jalview.util.QuickSort.sort(spos, svcs); + services=new Vector(); + for (Jws2Instance svc:svcs) { + services.add(svc); + } + } } + oldthread = null; + running = false; + changeSupport.firePropertyChange("services", new Vector(), services); } /** @@ -251,9 +284,9 @@ public class Jws2Discoverer implements Runnable, WSMenuEntryProviderI MsaWSClient msacl = new MsaWSClient(); Vector hostLabels = new Vector(); jws2al.removeAll(); - String lasthost = null; + Hashtable lasthostFor = new Hashtable(); Hashtable> hosts = new Hashtable>(); - String[] sorton; + ArrayList hostlist=new ArrayList(); for (Jws2Instance service : services) { ArrayList hostservices = hosts.get(service.getHost()); @@ -261,12 +294,11 @@ public class Jws2Discoverer implements Runnable, WSMenuEntryProviderI { hosts.put(service.getHost(), hostservices = new ArrayList()); + hostlist.add(service.getHost()); } hostservices.add(service); } - sorton = hosts.keySet().toArray(new String[1]); - String hostlist[] = sorton.clone(); - jalview.util.QuickSort.sort(sorton, hostlist); + // now add hosts in order of the given array for (String host : hostlist) { Jws2Instance orderedsvcs[] = hosts.get(host).toArray( @@ -309,7 +341,7 @@ public class Jws2Discoverer implements Runnable, WSMenuEntryProviderI // group JMenuItem hitm; atpoint.addSeparator(); - if (lasthost == null || !lasthost.equals(host)) + if (lasthostFor.get(service.action) == null || !lasthostFor.get(service.action).equals(host)) { atpoint.add(hitm = new JMenuItem(host)); hitm.setForeground(Color.blue); @@ -324,7 +356,7 @@ public class Jws2Discoverer implements Runnable, WSMenuEntryProviderI }); hitm.setToolTipText(JvSwingUtils .wrapTooltip("Opens the JABAWS server's homepage in web browser")); - lasthost = host; + lasthostFor.put(service.action,host); } hostLabels.addElement(host + service.serviceType + service.getActionText()); @@ -370,6 +402,11 @@ public class Jws2Discoverer implements Runnable, WSMenuEntryProviderI { System.out.println("Changesupport: There are now " + getDiscoverer().services.size() + " services"); + int i=1; + for (Jws2Instance instance:getDiscoverer().services) + { + System.out.println("Service "+i+++" "+instance.getClass()+"@"+instance.getHost()+": "+instance.getActionText()); + } } } @@ -384,6 +421,9 @@ public class Jws2Discoverer implements Runnable, WSMenuEntryProviderI } ; } + try { + Thread.sleep(50); + } catch (InterruptedException x) {} } private static Jws2Discoverer discoverer;