# HG changeset patch # User ryall # Date 1243455905 18000 # Node ID b95605ba86771f42f95cb03f74ea8a3f1d052bb5 # Parent 79d8b140b8cde49d18621532223d86841b46501c# Parent cf4891b2fe556022e2efc25dca4deb361377a4d5 Apply CDT patch to prevent refreshing of exe list. diff -r cf4891b2fe55 -r b95605ba8677 cdt/cdt_5_0_x/org.eclipse.cdt.debug.core/src/org/eclipse/cdt/debug/core/executables/ExecutablesManager.java --- a/cdt/cdt_5_0_x/org.eclipse.cdt.debug.core/src/org/eclipse/cdt/debug/core/executables/ExecutablesManager.java Tue May 26 13:54:40 2009 -0500 +++ b/cdt/cdt_5_0_x/org.eclipse.cdt.debug.core/src/org/eclipse/cdt/debug/core/executables/ExecutablesManager.java Wed May 27 15:25:05 2009 -0500 @@ -40,16 +40,16 @@ */ public class ExecutablesManager extends PlatformObject { - private HashMap executables = new HashMap(); - private List changeListeners = Collections.synchronizedList(new ArrayList()); - private List sourceFileRemappings = Collections.synchronizedList(new ArrayList()); - private List executableProviders = Collections.synchronizedList(new ArrayList()); - private List sourceFileProviders = Collections.synchronizedList(new ArrayList()); - private List executableImporters = Collections.synchronizedList(new ArrayList()); + private final HashMap executables = new HashMap(); + private final List changeListeners = Collections.synchronizedList(new ArrayList()); + private final List sourceFileRemappings = Collections.synchronizedList(new ArrayList()); + private final List executableProviders = Collections.synchronizedList(new ArrayList()); + private final List sourceFileProviders = Collections.synchronizedList(new ArrayList()); + private final List executableImporters = Collections.synchronizedList(new ArrayList()); private boolean refreshNeeded = true; private boolean tempDisableRefresh = false; - private Job refreshJob = new Job("Get Executables") { + private final Job refreshJob = new Job("Get Executables") { @Override public IStatus run(IProgressMonitor monitor) { @@ -190,6 +190,7 @@ } public void importExecutables(final String[] fileNames, IProgressMonitor monitor) { + boolean handled = false; try { tempDisableRefresh = true; @@ -208,7 +209,7 @@ }}); for (IExecutableImporter importer : executableImporters) { - boolean handled = importer.importExecutables(fileNames, new SubProgressMonitor(monitor, 1)); + handled = importer.importExecutables(fileNames, new SubProgressMonitor(monitor, 1)); if (handled || monitor.isCanceled()) { break; } @@ -219,7 +220,8 @@ tempDisableRefresh = false; } - refreshExecutables(monitor); + if (handled) + refreshExecutables(monitor); monitor.done(); } diff -r cf4891b2fe55 -r b95605ba8677 cdt/cdt_5_0_x/org.eclipse.cdt.debug.core/src/org/eclipse/cdt/debug/core/executables/StandardExecutableImporter.java --- a/cdt/cdt_5_0_x/org.eclipse.cdt.debug.core/src/org/eclipse/cdt/debug/core/executables/StandardExecutableImporter.java Tue May 26 13:54:40 2009 -0500 +++ b/cdt/cdt_5_0_x/org.eclipse.cdt.debug.core/src/org/eclipse/cdt/debug/core/executables/StandardExecutableImporter.java Wed May 27 15:25:05 2009 -0500 @@ -60,6 +60,7 @@ IProject exeProject = null; boolean checkProject = false; + boolean handled = false; // Weed out existing ones for (String path : fileNames) { @@ -117,6 +118,7 @@ } importExecutable(exeProject, path); + handled = true; } monitor.worked(1); if (monitor.isCanceled()) { @@ -124,7 +126,7 @@ } } monitor.done(); - return true; + return handled; } public boolean AllowImport(IPath path) {