* server is a WSDL2Java generated stub for an archetypal MsaWSI service.
*/
MsaWS server;
+
AlignFrame alignFrame;
+
private Preset preset;
- private List<Argument> paramset;
+ private List<Argument> paramset;
public MsaWSClient(Jws2Discoverer.Jws2Instance sh, String altitle,
jalview.datamodel.AlignmentView msa, boolean submitGaps,
boolean preserveOrder, Alignment seqdataset,
AlignFrame _alignFrame)
{
- this(sh, null, null, altitle, msa, submitGaps, preserveOrder, seqdataset, _alignFrame);
+ this(sh, null, null, false, altitle, msa, submitGaps, preserveOrder,
+ seqdataset, _alignFrame);
// TODO Auto-generated constructor stub
}
- public MsaWSClient(Jws2Discoverer.Jws2Instance sh, Preset preset, String altitle,
- jalview.datamodel.AlignmentView msa, boolean submitGaps,
- boolean preserveOrder, Alignment seqdataset,
+ public MsaWSClient(Jws2Discoverer.Jws2Instance sh, Preset preset,
+ String altitle, jalview.datamodel.AlignmentView msa,
+ boolean submitGaps, boolean preserveOrder, Alignment seqdataset,
AlignFrame _alignFrame)
{
- this(sh, preset, null, altitle, msa, submitGaps, preserveOrder, seqdataset, _alignFrame);
+ this(sh, preset, null, false, altitle, msa, submitGaps, preserveOrder,
+ seqdataset, _alignFrame);
// TODO Auto-generated constructor stub
}
+
/**
* Creates a new MsaWSClient object that uses a service given by an externally
* retrieved ServiceHandle
* DOCUMENT ME!
*/
- public MsaWSClient(Jws2Discoverer.Jws2Instance sh, Preset preset, List<Argument> arguments, String altitle,
+ public MsaWSClient(Jws2Discoverer.Jws2Instance sh, Preset preset,
+ List<Argument> arguments, boolean editParams, String altitle,
jalview.datamodel.AlignmentView msa, boolean submitGaps,
boolean preserveOrder, Alignment seqdataset,
- AlignFrame _alignFrame) {
+ AlignFrame _alignFrame)
+ {
super();
alignFrame = _alignFrame;
if (!(sh.service instanceof MsaWS))
server = sh.service;
this.preset = preset;
this.paramset = arguments;
+ if (editParams)
+ {
+ WsJobParameters jobParams = new WsJobParameters(sh, preset);
+ if (!jobParams.showRunDialog())
+ {
+ return;
+ }
+ preset = null;
+ paramset = jobParams.getJobParams();
+ }
+
if ((wsInfo = setWebService(sh, false)) == null)
{
JOptionPane.showMessageDialog(Desktop.desktop,
private void startMsaWSClient(String altitle, AlignmentView msa,
boolean submitGaps, boolean preserveOrder, Alignment seqdataset)
{
- //if (!locateWebService())
- // {
- // return;
- // }
+ // if (!locateWebService())
+ // {
+ // return;
+ // }
wsInfo.setProgressText(((submitGaps) ? "Re-alignment" : "Alignment")
+ " of " + altitle + "\nJob details\n");
+ "alignment of " + altitle;
}
- MsaWSThread msathread = new MsaWSThread(server, preset, paramset, WsURL, wsInfo,
- alignFrame, WebServiceName, jobtitle, msa, submitGaps,
- preserveOrder, seqdataset);
+ MsaWSThread msathread = new MsaWSThread(server, preset, paramset,
+ WsURL, wsInfo, alignFrame, WebServiceName, jobtitle, msa,
+ submitGaps, preserveOrder, seqdataset);
wsInfo.setthisService(msathread);
msathread.start();
}
return (WebServiceName.indexOf("lustal") > -1); // cheat!
}
- public void attachWSMenuEntry(JMenu msawsmenu,
+ public void attachWSMenuEntry(JMenu rmsawsmenu,
final Jws2Instance service, final AlignFrame alignFrame)
{
setWebService(service, true); // headless
- JMenuItem method = new JMenuItem(WebServiceName);
- method.setToolTipText(WsURL);
- method.addActionListener(new ActionListener()
+ boolean finished = true, submitGaps = false;
+ JMenu msawsmenu = rmsawsmenu;
+ String calcName = WebServiceName + " ";
+ if (canSubmitGaps())
{
- public void actionPerformed(ActionEvent e)
- {
- AlignmentView msa = alignFrame.gatherSequencesForAlignment();
- new MsaWSClient(service, alignFrame.getTitle(),
- msa, false, true, alignFrame.getViewport().getAlignment()
- .getDataset(), alignFrame);
+ msawsmenu = new JMenu(WebServiceName);
+ rmsawsmenu.add(msawsmenu);
+ calcName = "";
+ }
+ do
+ {
+ if (submitGaps == true)
+ {
+ msawsmenu = new JMenu("profile " + WebServiceName);
+ rmsawsmenu.add(msawsmenu);
}
+ final boolean withGaps = submitGaps;
+ JMenuItem method = new JMenuItem(calcName + "Defaults");
+ method.setToolTipText(WsURL);
- });
- msawsmenu.add(method);
- if (canSubmitGaps())
- {
- // We know that ClustalWS can accept partial alignments for refinement.
- final JMenuItem methodR = new JMenuItem(WebServiceName
- + " (With Gaps)");
- methodR.setToolTipText(WsURL);
- methodR.addActionListener(new ActionListener()
+ method.addActionListener(new ActionListener()
{
public void actionPerformed(ActionEvent e)
{
AlignmentView msa = alignFrame.gatherSequencesForAlignment();
- new MsaWSClient(service, alignFrame.getTitle(),
- msa, true, true, alignFrame.getViewport().getAlignment()
+ new MsaWSClient(service, alignFrame.getTitle(), msa, withGaps,
+ true, alignFrame.getViewport().getAlignment()
.getDataset(), alignFrame);
}
-
});
- msawsmenu.add(methodR);
+ msawsmenu.add(method);
+ method = new JMenuItem(calcName + " Edit Parameters...");
+ method.setToolTipText(WsURL);
- }
- PresetManager presets = service.getPresets();
- if (presets!=null && presets.getPresets().size()>0)
- {
- JMenu presetlist = new JMenu("Presets for "+WebServiceName+"(Without gaps)");
-
- for (final Preset preset : (List<Preset>) presets.getPresets())
+ method.addActionListener(new ActionListener()
+ {
+ public void actionPerformed(ActionEvent e)
+ {
+ AlignmentView msa = alignFrame.gatherSequencesForAlignment();
+ new MsaWSClient(service, null, null, true, alignFrame.getTitle(),
+ msa, withGaps, true, alignFrame.getViewport()
+ .getAlignment().getDataset(), alignFrame);
+
+ }
+ });
+ msawsmenu.add(method);
+ PresetManager presets = service.getPresets();
+ if (presets != null && presets.getPresets().size() > 0)
{
- final JMenuItem methodR = new JMenuItem(preset.getName());
- methodR.setToolTipText(preset.getDescription());
- methodR.addActionListener(new ActionListener()
+ JMenu presetlist = new JMenu(calcName + "Presets");
+
+ for (final Preset preset : (List<Preset>) presets.getPresets())
{
- public void actionPerformed(ActionEvent e)
+ final JMenuItem methodR = new JMenuItem(preset.getName());
+ methodR.setToolTipText(preset.getDescription());
+ methodR.addActionListener(new ActionListener()
{
- AlignmentView msa = alignFrame.gatherSequencesForAlignment();
- new MsaWSClient(service, preset, alignFrame.getTitle(),
- msa, false, true, alignFrame.getViewport().getAlignment()
- .getDataset(), alignFrame);
+ public void actionPerformed(ActionEvent e)
+ {
+ AlignmentView msa = alignFrame.gatherSequencesForAlignment();
+ new MsaWSClient(service, preset, alignFrame.getTitle(), msa,
+ false, true, alignFrame.getViewport().getAlignment()
+ .getDataset(), alignFrame);
- }
+ }
- });
- presetlist.add(methodR);
+ });
+ presetlist.add(methodR);
+ }
+ msawsmenu.add(presetlist);
}
- msawsmenu.add(presetlist);
- }
-
+ if (!submitGaps && canSubmitGaps())
+ {
+ submitGaps = true;
+ finished = false;
+ }
+ else
+ {
+ finished = true;
+ }
+ } while (!finished);
}
-
}