diff options
author | Andrew Gvozdev | 2011-03-11 19:12:48 +0000 |
---|---|---|
committer | Andrew Gvozdev | 2011-03-11 19:12:48 +0000 |
commit | 1db8cc744d1eb148b1277bcb6128ae8c37b7b734 (patch) | |
tree | f1dae07ecd8d7165928000db3ce405c0ebfc1e2e /build | |
parent | 112b975c2d9db87c43b42437bd5c2eaf20f2257e (diff) | |
download | org.eclipse.cdt-1db8cc744d1eb148b1277bcb6128ae8c37b7b734.tar.gz org.eclipse.cdt-1db8cc744d1eb148b1277bcb6128ae8c37b7b734.tar.xz org.eclipse.cdt-1db8cc744d1eb148b1277bcb6128ae8c37b7b734.zip |
bug 339015: Preference "Show source roots at the top of project" should update views immediately
Diffstat (limited to 'build')
-rw-r--r-- | build/org.eclipse.cdt.make.ui/src/org/eclipse/cdt/make/ui/MakeContentProvider.java | 27 |
1 files changed, 25 insertions, 2 deletions
diff --git a/build/org.eclipse.cdt.make.ui/src/org/eclipse/cdt/make/ui/MakeContentProvider.java b/build/org.eclipse.cdt.make.ui/src/org/eclipse/cdt/make/ui/MakeContentProvider.java index b133397009e..06d5f0ef584 100644 --- a/build/org.eclipse.cdt.make.ui/src/org/eclipse/cdt/make/ui/MakeContentProvider.java +++ b/build/org.eclipse.cdt.make.ui/src/org/eclipse/cdt/make/ui/MakeContentProvider.java @@ -19,6 +19,7 @@ import java.util.List; import java.util.Set; import org.eclipse.cdt.core.CCorePlugin; +import org.eclipse.cdt.core.CCorePreferenceConstants; import org.eclipse.cdt.core.model.CoreModel; import org.eclipse.cdt.core.settings.model.CProjectDescriptionEvent; import org.eclipse.cdt.core.settings.model.ICConfigurationDescription; @@ -41,6 +42,9 @@ import org.eclipse.core.resources.IResourceDelta; import org.eclipse.core.resources.IWorkspace; import org.eclipse.core.resources.IWorkspaceRoot; import org.eclipse.core.runtime.CoreException; +import org.eclipse.core.runtime.preferences.IEclipsePreferences.IPreferenceChangeListener; +import org.eclipse.core.runtime.preferences.IEclipsePreferences.PreferenceChangeEvent; +import org.eclipse.core.runtime.preferences.InstanceScope; import org.eclipse.jface.viewers.AbstractTreeViewer; import org.eclipse.jface.viewers.ITreeContentProvider; import org.eclipse.jface.viewers.StructuredViewer; @@ -55,7 +59,9 @@ import org.eclipse.swt.widgets.Display; * @noextend This class is not intended to be subclassed by clients. * @noinstantiate This class is not intended to be instantiated by clients. */ -public class MakeContentProvider implements ITreeContentProvider, IMakeTargetListener, IResourceChangeListener, ICProjectDescriptionListener { +public class MakeContentProvider implements ITreeContentProvider, IMakeTargetListener, + IResourceChangeListener, ICProjectDescriptionListener, IPreferenceChangeListener { + /** presentation of the content, i.e. for MakeView tree of for BuildTargetDialog table */ protected boolean bFlatten; @@ -224,12 +230,14 @@ public class MakeContentProvider implements ITreeContentProvider, IMakeTargetLis if (oldWorkspace != newWorkspace) { ICProjectDescriptionManager mngr = CoreModel.getDefault().getProjectDescriptionManager(); if (oldWorkspace != null) { - oldWorkspace.removeResourceChangeListener(this); + InstanceScope.INSTANCE.getNode(CCorePlugin.PLUGIN_ID).removePreferenceChangeListener(this); mngr.removeCProjectDescriptionListener(this); + oldWorkspace.removeResourceChangeListener(this); } if (newWorkspace != null) { newWorkspace.addResourceChangeListener(this, IResourceChangeEvent.POST_CHANGE); mngr.addCProjectDescriptionListener(this, CProjectDescriptionEvent.APPLIED); + InstanceScope.INSTANCE.getNode(CCorePlugin.PLUGIN_ID).addPreferenceChangeListener(this); } } } @@ -406,6 +414,21 @@ public class MakeContentProvider implements ITreeContentProvider, IMakeTargetLis } /** + * {@inheritDoc} + * + * @since 7.1 + */ + public void preferenceChange(PreferenceChangeEvent event) { + if (event.getKey().equals(CCorePreferenceConstants.SHOW_SOURCE_ROOTS_AT_TOP_LEVEL_OF_PROJECT)) { + Display.getDefault().asyncExec(new Runnable() { + public void run() { + viewer.refresh(); + } + }); + } + } + + /** * Get source entries for default setting configuration (i.e. configuration shown in UI). */ private static ICSourceEntry[] getSourceEntries(IProject project) { |