2 * Jalview - A Sequence Alignment Editor and Viewer (Version 2.8.2)
3 * Copyright (C) 2014 The Jalview Authors
5 * This file is part of Jalview.
7 * Jalview is free software: you can redistribute it and/or
8 * modify it under the terms of the GNU General Public License
9 * as published by the Free Software Foundation, either version 3
10 * of the License, or (at your option) any later version.
12 * Jalview is distributed in the hope that it will be useful, but
13 * WITHOUT ANY WARRANTY; without even the implied warranty
14 * of MERCHANTABILITY or FITNESS FOR A PARTICULAR
15 * PURPOSE. See the GNU General Public License for more details.
17 * You should have received a copy of the GNU General Public License
18 * along with Jalview. If not, see <http://www.gnu.org/licenses/>.
19 * The Jalview Authors are detailed in the 'AUTHORS' file.
21 package jalview.ws.jws2;
23 import jalview.datamodel.Alignment;
24 import jalview.datamodel.AlignmentView;
25 import jalview.datamodel.SequenceI;
26 import jalview.gui.AlignFrame;
27 import jalview.gui.Desktop;
28 import jalview.gui.JvSwingUtils;
29 import jalview.util.MessageManager;
30 import jalview.ws.jws2.jabaws2.Jws2Instance;
31 import jalview.ws.params.WsParamSetI;
33 import java.awt.event.ActionEvent;
34 import java.awt.event.ActionListener;
35 import java.awt.event.MouseAdapter;
36 import java.awt.event.MouseEvent;
37 import java.util.List;
39 import javax.swing.JMenu;
40 import javax.swing.JMenuItem;
41 import javax.swing.JOptionPane;
42 import javax.swing.ToolTipManager;
44 import compbio.data.msa.MsaWS;
45 import compbio.metadata.Argument;
53 public class MsaWSClient extends Jws2Client
56 * server is a WSDL2Java generated stub for an archetypal MsaWSI service.
60 public MsaWSClient(Jws2Instance sh, String altitle,
61 jalview.datamodel.AlignmentView msa, boolean submitGaps,
62 boolean preserveOrder, Alignment seqdataset,
63 AlignFrame _alignFrame)
65 this(sh, null, null, false, altitle, msa, submitGaps, preserveOrder,
66 seqdataset, _alignFrame);
67 // TODO Auto-generated constructor stub
70 public MsaWSClient(Jws2Instance sh, WsParamSetI preset, String altitle,
71 jalview.datamodel.AlignmentView msa, boolean submitGaps,
72 boolean preserveOrder, Alignment seqdataset,
73 AlignFrame _alignFrame)
75 this(sh, preset, null, false, altitle, msa, submitGaps, preserveOrder,
76 seqdataset, _alignFrame);
77 // TODO Auto-generated constructor stub
81 * Creates a new MsaWSClient object that uses a service given by an externally
82 * retrieved ServiceHandle
85 * service handle of type AbstractName(MsaWS)
92 * @param preserveOrder
96 public MsaWSClient(Jws2Instance sh, WsParamSetI preset,
97 List<Argument> arguments, boolean editParams, String altitle,
98 jalview.datamodel.AlignmentView msa, boolean submitGaps,
99 boolean preserveOrder, Alignment seqdataset,
100 AlignFrame _alignFrame)
102 super(_alignFrame, preset, arguments);
103 if (!processParams(sh, editParams))
108 if (!(sh.service instanceof MsaWS))
110 // redundant at mo - but may change
111 JOptionPane.showMessageDialog(Desktop.desktop, MessageManager
112 .formatMessage("label.service_called_is_not_msa_service",
114 { sh.serviceType }), MessageManager
115 .getString("label.internal_jalview_error"),
116 JOptionPane.WARNING_MESSAGE);
120 server = (MsaWS) sh.service;
121 if ((wsInfo = setWebService(sh, false)) == null)
123 JOptionPane.showMessageDialog(Desktop.desktop, MessageManager
124 .formatMessage("label.msa_service_is_unknown", new String[]
125 { sh.serviceType }), MessageManager
126 .getString("label.internal_jalview_error"),
127 JOptionPane.WARNING_MESSAGE);
132 startMsaWSClient(altitle, msa, submitGaps, preserveOrder, seqdataset);
140 // add a class reference to the list
143 private void startMsaWSClient(String altitle, AlignmentView msa,
144 boolean submitGaps, boolean preserveOrder, Alignment seqdataset)
146 // if (!locateWebService())
151 wsInfo.setProgressText(((submitGaps) ? "Re-alignment" : "Alignment")
152 + " of " + altitle + "\nJob details\n");
153 String jobtitle = WebServiceName.toLowerCase();
154 if (jobtitle.endsWith("alignment"))
157 && (!jobtitle.endsWith("realignment") || jobtitle
158 .indexOf("profile") == -1))
160 int pos = jobtitle.indexOf("alignment");
161 jobtitle = WebServiceName.substring(0, pos) + "re-alignment of "
166 jobtitle = WebServiceName + " of " + altitle;
171 jobtitle = WebServiceName + (submitGaps ? " re" : " ")
172 + "alignment of " + altitle;
175 MsaWSThread msathread = new MsaWSThread(server, preset, paramset,
176 WsURL, wsInfo, alignFrame, WebServiceName, jobtitle, msa,
177 submitGaps, preserveOrder, seqdataset);
178 wsInfo.setthisService(msathread);
184 private boolean isValidAlignment(AlignmentView av)
186 int validSeqCount = 0;
187 List<SequenceI> seqs = av.getVisibleAlignment('c').getSequences(); // .getSequences();
193 "A minimum of two sequences is required to perform this operation",
194 "Invalid selection", JOptionPane.INFORMATION_MESSAGE);
199 for (SequenceI seq : seqs)
202 if (seq.getSequenceAsString().matches(
203 "([(a-zA-Z?)(-?)(.?)]+)?[a-zA-Z]([(a-zA-Z?)(-?)(.?)]+)?"))
207 if (validSeqCount > 1)
216 "A minimum of two sequences with at least one non-gap character \nin each sequence is required to perform this operation",
217 "Invalid selection", JOptionPane.INFORMATION_MESSAGE);
222 public static void main(String[] args)
226 .matches("([(a-zA-Z?)(-?)(.?)]+)?[a-zA-Z]([(a-zA-Z?)(-?)(.?)]+)?"));
231 protected String getServiceActionKey()
236 protected String getServiceActionDescription()
238 return "Multiple Sequence Alignment";
242 * look at ourselves and work out if we are a service that can take a profile
245 * @return true if we can send gapped sequences to the alignment service
247 private boolean canSubmitGaps()
249 // TODO: query service or extract service handle props to check if we can
251 return (WebServiceName.indexOf("lustal") > -1); // cheat!
254 public void attachWSMenuEntry(JMenu rmsawsmenu,
255 final Jws2Instance service, final AlignFrame alignFrame)
257 if (registerAAConWSInstance(rmsawsmenu, service, alignFrame))
259 // Alignment dependent analysis calculation WS gui
262 setWebService(service, true); // headless
263 boolean finished = true, submitGaps = false;
264 JMenu msawsmenu = rmsawsmenu;
265 String svcname = WebServiceName;
266 if (svcname.endsWith("WS"))
268 svcname = svcname.substring(0, svcname.length() - 2);
270 String calcName = svcname + " ";
273 msawsmenu = new JMenu(svcname);
274 rmsawsmenu.add(msawsmenu);
277 boolean hasparams = service.hasParameters();
280 String action = "Align ";
281 if (submitGaps == true)
284 msawsmenu = new JMenu(MessageManager.formatMessage(
285 "label.realign_with_params", new String[]
287 msawsmenu.setToolTipText(MessageManager
288 .getString("label.align_sequences_to_existing_alignment"));
289 rmsawsmenu.add(msawsmenu);
291 final boolean withGaps = submitGaps;
293 JMenuItem method = new JMenuItem(MessageManager.formatMessage(
294 "label.calcname_with_default_settings", new String[]
296 method.setToolTipText(MessageManager.formatMessage(
297 "label.action_with_default_settings", new String[]
300 method.addActionListener(new ActionListener()
302 public void actionPerformed(ActionEvent e)
304 AlignmentView msa = alignFrame.gatherSequencesForAlignment();
306 if (isValidAlignment(msa))
308 new MsaWSClient(service, alignFrame.getTitle(), msa, withGaps,
309 true, alignFrame.getViewport().getAlignment()
310 .getDataset(), alignFrame);
315 msawsmenu.add(method);
318 // only add these menu options if the service has user-modifiable
320 method = new JMenuItem(
321 MessageManager.getString("label.edit_settings_and_run"));
322 method.setToolTipText(MessageManager
323 .getString("label.view_and_change_parameters_before_alignment"));
325 method.addActionListener(new ActionListener()
327 public void actionPerformed(ActionEvent e)
329 AlignmentView msa = alignFrame.gatherSequencesForAlignment();
331 if (isValidAlignment(msa))
333 new MsaWSClient(service, null, null, true, alignFrame
334 .getTitle(), msa, withGaps, true, alignFrame
335 .getViewport().getAlignment().getDataset(), alignFrame);
340 msawsmenu.add(method);
341 List<WsParamSetI> presets = service.getParamStore().getPresets();
342 if (presets != null && presets.size() > 0)
344 JMenu presetlist = new JMenu(MessageManager.formatMessage(
345 "label.run_with_preset_params", new String[]
348 final int showToolTipFor = ToolTipManager.sharedInstance()
350 for (final WsParamSetI preset : presets)
352 final JMenuItem methodR = new JMenuItem(preset.getName());
353 final int QUICK_TOOLTIP = 1500;
354 // JAL-1582 shorten tooltip display time in these menu items as
355 // they can obscure other options
356 methodR.addMouseListener(new MouseAdapter()
359 public void mouseEntered(MouseEvent e)
361 ToolTipManager.sharedInstance().setDismissDelay(
366 public void mouseExited(MouseEvent e)
368 ToolTipManager.sharedInstance().setDismissDelay(showToolTipFor);
372 methodR.setToolTipText(JvSwingUtils.wrapTooltip(
375 + (preset.isModifiable() ? MessageManager
376 .getString("label.user_preset")
378 .getString("label.service_preset"))
379 + "</strong><br/>" + preset.getDescription()
381 methodR.addActionListener(new ActionListener()
383 public void actionPerformed(ActionEvent e)
385 AlignmentView msa = alignFrame
386 .gatherSequencesForAlignment();
388 if (isValidAlignment(msa))
390 new MsaWSClient(service, preset, alignFrame.getTitle(),
391 msa, false, true, alignFrame.getViewport()
392 .getAlignment().getDataset(), alignFrame);
398 presetlist.add(methodR);
400 msawsmenu.add(presetlist);
403 if (!submitGaps && canSubmitGaps())