diff options
author | Alena Laskavaia | 2008-12-12 14:18:18 +0000 |
---|---|---|
committer | Alena Laskavaia | 2008-12-12 14:18:18 +0000 |
commit | 46fe6ca136430e461757e8a9d2e5ac1e21cb5133 (patch) | |
tree | d98cba1920d565236b8f71b3970d4cd08528f516 /build/org.eclipse.cdt.managedbuilder.ui | |
parent | c028cfdff92d939c6b977b1fb2f5dc09589cfbb2 (diff) | |
download | org.eclipse.cdt-46fe6ca136430e461757e8a9d2e5ac1e21cb5133.tar.gz org.eclipse.cdt-46fe6ca136430e461757e8a9d2e5ac1e21cb5133.tar.xz org.eclipse.cdt-46fe6ca136430e461757e8a9d2e5ac1e21cb5133.zip |
242403 - applied patch to solve ClassCastException
Diffstat (limited to 'build/org.eclipse.cdt.managedbuilder.ui')
-rw-r--r-- | build/org.eclipse.cdt.managedbuilder.ui/src/org/eclipse/cdt/managedbuilder/ui/properties/BuildOptionSettingsUI.java | 45 |
1 files changed, 33 insertions, 12 deletions
diff --git a/build/org.eclipse.cdt.managedbuilder.ui/src/org/eclipse/cdt/managedbuilder/ui/properties/BuildOptionSettingsUI.java b/build/org.eclipse.cdt.managedbuilder.ui/src/org/eclipse/cdt/managedbuilder/ui/properties/BuildOptionSettingsUI.java index 62070c734e5..e8e742ca570 100644 --- a/build/org.eclipse.cdt.managedbuilder.ui/src/org/eclipse/cdt/managedbuilder/ui/properties/BuildOptionSettingsUI.java +++ b/build/org.eclipse.cdt.managedbuilder.ui/src/org/eclipse/cdt/managedbuilder/ui/properties/BuildOptionSettingsUI.java @@ -30,6 +30,7 @@ import org.eclipse.cdt.managedbuilder.core.IOptionApplicability; import org.eclipse.cdt.managedbuilder.core.IOptionCategory; import org.eclipse.cdt.managedbuilder.core.IResourceInfo; import org.eclipse.cdt.managedbuilder.core.ITool; +import org.eclipse.cdt.managedbuilder.core.IToolChain; import org.eclipse.cdt.managedbuilder.core.ManagedBuildManager; import org.eclipse.cdt.managedbuilder.internal.core.MultiResourceInfo; import org.eclipse.cdt.ui.newui.AbstractCPropertyTab; @@ -53,8 +54,10 @@ public class BuildOptionSettingsUI extends AbstractToolSettingUI { new HashMap<String, FieldEditor>(); private IOptionCategory category; private IHoldsOptions optionHolder; + /** Option Holders involved */ private IHoldsOptions[] ohs; - private int curr; + /** The index of the current IHoldsOptions in ohs */ + private int curr = -1; private Map<FieldEditor, Composite> fieldEditorsToParentMap = new HashMap<FieldEditor, Composite>(); @@ -69,25 +72,43 @@ public class BuildOptionSettingsUI extends AbstractToolSettingUI { MultiResourceInfo mri = (MultiResourceInfo)info; IResourceInfo[] ris = (IResourceInfo[])mri.getItems(); String id = category.getId(); - String ext = ((ITool)optionHolder).getDefaultInputExtension(); - ArrayList<ITool> lst = new ArrayList<ITool>(); - for (int i=0; i<ris.length; i++) { - ITool[] ts = ris[i].getTools(); - for (int j=0; j<ts.length; j++) { - IOptionCategory op = ts[j].getOptionCategory(id); - if (op != null) { - if (ext.equals(ts[j].getDefaultInputExtension())) - lst.add(ts[j]); + + /* + * Collect together all the IHoldsOptions (ITools & IToolChains) + * from the MultiResourceInfo's set of selected configs + * which contain the option category and accept the input type + * of this option holder. + */ + ArrayList<IHoldsOptions> lst = new ArrayList<IHoldsOptions>(); + if (optionHolder instanceof ITool) { + String ext = ((ITool)optionHolder).getDefaultInputExtension(); + for (int i=0; i<ris.length; i++) { + ITool[] ts = ris[i].getTools(); + for (int j=0; j<ts.length; j++) { + IOptionCategory op = ts[j].getOptionCategory(id); + if (op != null) { + if (ext.equals(ts[j].getDefaultInputExtension())) { + lst.add(ts[j]); + } + } } - } + } + } else if (optionHolder instanceof IToolChain) { + for (int i=0; i<ris.length; i++) { + IToolChain tc = ris[i].getParent().getToolChain(); + IOptionCategory op = tc.getOptionCategory(id); + if (op != null) + lst.add(tc); + } } + ohs = (IHoldsOptions[])lst.toArray(new IHoldsOptions[lst.size()]); for (int i=0; i<ohs.length; i++) { if (ohs[i].equals(optionHolder)) { curr = i; break; } - } + } } else { ohs = null; curr = 0; |