# HG changeset patch # User Ed Swartz # Date 1272387446 18000 # Node ID dd0c4e59db518af466d7e56f53cc813c717a8bc3 # Parent c6abac939087ff3e9523880bcda1f3fb7382695f# Parent 8aac8dbed77395404bf4535b2d1b98327f567dc4 Merge commit diff -r 8aac8dbed773 -r dd0c4e59db51 debuggercdi/com.nokia.cdt.debug.launch/src/com/nokia/cdt/internal/debug/launch/LaunchPlugin.java --- a/debuggercdi/com.nokia.cdt.debug.launch/src/com/nokia/cdt/internal/debug/launch/LaunchPlugin.java Tue Apr 27 11:44:56 2010 -0500 +++ b/debuggercdi/com.nokia.cdt.debug.launch/src/com/nokia/cdt/internal/debug/launch/LaunchPlugin.java Tue Apr 27 11:57:26 2010 -0500 @@ -346,7 +346,7 @@ openLaunchConfigDialog = wizard.shouldOpenLaunchConfigurationDialog(); } catch (Exception e) { - throw new CoreException(new Status(IStatus.ERROR, getUniqueIdentifier(), 0, e.getMessage(), null )); //$NON-NLS-1$ + throw new CoreException(new Status(IStatus.ERROR, getUniqueIdentifier(), 0, e.getMessage(), e )); //$NON-NLS-1$ } } diff -r 8aac8dbed773 -r dd0c4e59db51 debuggercdi/com.nokia.cdt.debug.launch/src/com/nokia/cdt/internal/debug/launch/wizard/LaunchCreationWizard.java --- a/debuggercdi/com.nokia.cdt.debug.launch/src/com/nokia/cdt/internal/debug/launch/wizard/LaunchCreationWizard.java Tue Apr 27 11:44:56 2010 -0500 +++ b/debuggercdi/com.nokia.cdt.debug.launch/src/com/nokia/cdt/internal/debug/launch/wizard/LaunchCreationWizard.java Tue Apr 27 11:57:26 2010 -0500 @@ -30,6 +30,7 @@ import org.eclipse.core.runtime.Platform; import org.eclipse.debug.core.DebugPlugin; import org.eclipse.debug.core.ILaunchConfigurationWorkingCopy; +import org.eclipse.jface.wizard.IWizardPage; import org.eclipse.jface.wizard.Wizard; import org.eclipse.jface.wizard.WizardDialog; import org.eclipse.swt.widgets.Shell; @@ -54,6 +55,7 @@ private String configurationName; private List wizards = new ArrayList(); private String categoryId; + private AbstractLaunchWizard selectedWizard; public LaunchCreationWizard(IProject project, String configurationName, List mmps, List exes, IPath defaultExecutable, @@ -94,14 +96,13 @@ } } - if (fWizardSelectionPage != null) { - AbstractLaunchWizard wizard = ((AbstractLaunchWizard) fWizardSelectionPage.getSelectedWizard()); - wizard.performFinish(); - Pair exeAndMmp = wizard.getSelectedExeMmpPair(); - IPath processToLaunchTargetPath = wizard.getProcessToLaunchTargetPath(); + if (selectedWizard != null) { + selectedWizard.performFinish(); + Pair exeAndMmp = selectedWizard.getSelectedExeMmpPair(); + IPath processToLaunchTargetPath = selectedWizard.getProcessToLaunchTargetPath(); launchConfig = - fWizardSelectionPage.getSelectedWizard().createLaunchConfiguration(exeAndMmp.second, exeAndMmp.first, processToLaunchTargetPath); - shouldOpenLaunchDialog = fWizardSelectionPage.getSelectedWizard().shouldOpenLaunchConfigurationDialog(); + selectedWizard.createLaunchConfiguration(exeAndMmp.second, exeAndMmp.first, processToLaunchTargetPath); + shouldOpenLaunchDialog = selectedWizard.shouldOpenLaunchConfigurationDialog(); } return true; @@ -114,7 +115,21 @@ addPage(fEmulationSummaryPage); } else if (fWizardSelectionPage != null) { - addPage(fWizardSelectionPage); + List wizards = getWizardsForCategory(getCategoryId()); + if (wizards.size() > 1) { + addPage(fWizardSelectionPage); + } else { + // just directly "select" the single wizard and add its pages instead of using + // a wizard selection node, to avoid a needless intermediate selection page + AbstractLaunchWizard wizard = wizards.get(0); + for (IWizardPage page : wizard.getPages()) { + page.setWizard(null); + addPage(page); + } + setWindowTitle(wizard.getWindowTitle()); + fWizardSelectionPage = null; + selectedWizard = wizard; + } } } @@ -159,8 +174,8 @@ return categoryId; } - public List getWizardsForCategory(String categoryId) { - List wizardsInCatgegory = new ArrayList(); + public List getWizardsForCategory(String categoryId) { + List wizardsInCatgegory = new ArrayList(); for (AbstractLaunchWizard wizard : wizards) { if (wizard.supportsCategory(categoryId)) { wizardsInCatgegory.add(wizard); @@ -211,4 +226,8 @@ } } } + + public void setSelectedWizard(AbstractLaunchWizard selectedWizard) { + this.selectedWizard = selectedWizard; + } } diff -r 8aac8dbed773 -r dd0c4e59db51 debuggercdi/com.nokia.cdt.debug.launch/src/com/nokia/cdt/internal/debug/launch/wizard/LaunchWizardSelectionPage.java --- a/debuggercdi/com.nokia.cdt.debug.launch/src/com/nokia/cdt/internal/debug/launch/wizard/LaunchWizardSelectionPage.java Tue Apr 27 11:44:56 2010 -0500 +++ b/debuggercdi/com.nokia.cdt.debug.launch/src/com/nokia/cdt/internal/debug/launch/wizard/LaunchWizardSelectionPage.java Tue Apr 27 11:57:26 2010 -0500 @@ -47,7 +47,7 @@ private LaunchCreationWizard mainWizard; private FormBrowser descriptionBrowser; private TableViewer wizardSelectionTableViewer = null; - private ILaunchWizard selectedWizard = null; + private AbstractLaunchWizard selectedWizard = null; private boolean inputChanged = false; public LaunchWizardSelectionPage(LaunchCreationWizard mainWizard, List mmps, List exes, IPath defaultExecutable, IProject project, String configurationName, String mode) throws Exception { @@ -110,6 +110,8 @@ }); wizardSelectionTableViewer.addSelectionChangedListener(this); + wizardSelectionTableViewer.setInput(mainWizard.getWizardsForCategory(mainWizard.getCategoryId())); + createDescriptionIn(sashForm); sashForm.setWeights(new int[] {75, 25}); @@ -128,12 +130,14 @@ setErrorMessage(null); IStructuredSelection selection = (IStructuredSelection) event.getSelection(); Object selectedObject = null; - Iterator iter = selection.iterator(); + Iterator iter = selection.iterator(); if (iter.hasNext()) { selectedObject = iter.next(); - if (selectedObject instanceof ILaunchWizard) - selectedWizard = (ILaunchWizard)selectedObject; + if (selectedObject instanceof AbstractLaunchWizard) + selectedWizard = (AbstractLaunchWizard)selectedObject; } + mainWizard.setSelectedWizard(selectedWizard); + if (selectedWizard == null) { setDescriptionText(""); //$NON-NLS-1$ setSelectedNode(null); @@ -146,14 +150,16 @@ public void setVisible(boolean visible) { super.setVisible(visible); if (visible && wizardSelectionTableViewer != null) { - wizardSelectionTableViewer.setInput(mainWizard.getWizardsForCategory(mainWizard.getCategoryId())); if (inputChanged) { wizardSelectionTableViewer.setSelection(new StructuredSelection(wizardSelectionTableViewer.getElementAt(0)), true); } wizardSelectionTableViewer.getTable().setFocus(); } } + + + @SuppressWarnings("unchecked") public Object[] getElements(Object inputElement) { List wizards = (List)inputElement; return wizards.toArray();