1
0
Fork 0
mirror of https://github.com/eclipse-cdt/cdt synced 2025-06-30 21:55:31 +02:00

updated codan examples

Change-Id: I30bf2da294ec613917ce0f836f61709b1af9b513
Signed-off-by: Alena Laskavaia <elaskavaia.cdt@gmail.com>
This commit is contained in:
Alena Laskavaia 2015-03-04 08:41:12 -05:00 committed by Elena Laskavaia
parent a1b9cc4fbd
commit 0966863ef7
2 changed files with 49 additions and 40 deletions

View file

@ -14,7 +14,7 @@ import org.eclipse.cdt.codan.internal.core.model.CodanProblemMarker;
import org.eclipse.cdt.codan.ui.AbstractCodanProblemDetailsProvider;
/**
* Example of codan problem details provider for flexlint integration
* Example of codan problem details provider for string search integration
*/
public class GrepCheckerHelpLink extends AbstractCodanProblemDetailsProvider {
@Override

View file

@ -7,8 +7,7 @@
*
* Contributors:
* QNX Software Systems (Alena Laskavaia) - initial API and implementation
*******************************************************************************/
*******************************************************************************/
package org.eclipse.cdt.codan.examples.uicontrib;
import org.eclipse.cdt.codan.core.CodanCorePlugin;
@ -32,87 +31,97 @@ import org.eclipse.core.runtime.preferences.IEclipsePreferences.PreferenceChange
* Example of property change listener for changing error profiles
*/
public class ProfileChangeListener implements INodeChangeListener, IPreferenceChangeListener, IProblemProfileChangeListener {
static ProfileChangeListener instance = new ProfileChangeListener();
public static ProfileChangeListener getInstance(){
static ProfileChangeListener instance;
public static ProfileChangeListener getInstance() {
if (instance == null)
instance = new ProfileChangeListener();
return instance;
}
private IProject project;
private ProfileChangeListener(IProject project) {
this.project = project;
}
private ProfileChangeListener() {
CodanCorePlugin.getDefault().getStorePreferences().addNodeChangeListener(this);
CodanCorePlugin.getDefault().getStorePreferences().addPreferenceChangeListener(this);
IWorkspace root = ResourcesPlugin.getWorkspace();
IProject[] projects = root.getRoot().getProjects();
for (int i = 0; i < projects.length; i++) {
IWorkspace root = ResourcesPlugin.getWorkspace();
IProject[] projects = root.getRoot().getProjects();
for (int i = 0; i < projects.length; i++) {
IProject project = projects[i];
IEclipsePreferences prefs = CodanPreferencesLoader.getProjectNode(project);
if (prefs != null)
prefs.addPreferenceChangeListener(new ProfileChangeListener(project));
}
// cannot do on plugin startup
// CheckersRegistry.getInstance().getWorkspaceProfile().addProfileChangeListener(this);
// cannot do on plugin startup
// CheckersRegistry.getInstance().getWorkspaceProfile().addProfileChangeListener(this);
}
/* (non-Javadoc)
* @see org.eclipse.core.runtime.preferences.IEclipsePreferences.IPreferenceChangeListener#preferenceChange(org.eclipse.core.runtime.preferences.IEclipsePreferences.PreferenceChangeEvent)
*/
public void preferenceChange(PreferenceChangeEvent event) {
if (event.getSource() instanceof IEclipsePreferences) {
IEclipsePreferences ep = (IEclipsePreferences) event.getSource();
if (project!=null) {
if (GrepChecker.ID.equals(event.getKey())) {
// severity or enablement has changed
String val = (String) event.getNewValue();
if (!val.startsWith("-")) {
System.err.println("grep checker enabled!");
}
//IEclipsePreferences ep = (IEclipsePreferences) event.getSource();
if (GrepChecker.ID.equals(event.getKey())) {
// severity or enablement has changed
String val = (String) event.getNewValue();
if (!val.startsWith("-")) {
System.err.print("grep checker enabled :)");
} else {
System.err.print("grep checker disabled :(");
}
System.err.println(" for "+((project==null)?"workspace":project.getName()));
}
}
}
/* (non-Javadoc)
* @see org.eclipse.core.runtime.preferences.IEclipsePreferences.INodeChangeListener#added(org.eclipse.core.runtime.preferences.IEclipsePreferences.NodeChangeEvent)
/*
* (non-Javadoc)
*
* @see
* org.eclipse.core.runtime.preferences.IEclipsePreferences.INodeChangeListener
* #added(org.eclipse.core.runtime.preferences.IEclipsePreferences.
* NodeChangeEvent)
*/
public void added(NodeChangeEvent event) {
System.err.println("node added "+event);
System.err.println("node added " + event);
}
/* (non-Javadoc)
* @see org.eclipse.core.runtime.preferences.IEclipsePreferences.INodeChangeListener#removed(org.eclipse.core.runtime.preferences.IEclipsePreferences.NodeChangeEvent)
/*
* (non-Javadoc)
*
* @see
* org.eclipse.core.runtime.preferences.IEclipsePreferences.INodeChangeListener
* #removed(org.eclipse.core.runtime.preferences.IEclipsePreferences.
* NodeChangeEvent)
*/
public void removed(NodeChangeEvent event) {
// TODO Auto-generated method stub
System.err.println("node removed " + event);
}
/**
*
*/
public void dispose() {
CodanCorePlugin.getDefault().getStorePreferences().removeNodeChangeListener(this);
CodanCorePlugin.getDefault().getStorePreferences().removePreferenceChangeListener(this);
}
/* (non-Javadoc)
* @see org.eclipse.cdt.codan.internal.core.CheckersRegistry.IProblemProfileChangeListener#profileChange(org.eclipse.cdt.codan.internal.core.CheckersRegistry.ProblemProfileChangeEvent)
/*
* (non-Javadoc)
*
* @see org.eclipse.cdt.codan.internal.core.CheckersRegistry.
* IProblemProfileChangeListener
* #profileChange(org.eclipse.cdt.codan.internal
* .core.CheckersRegistry.ProblemProfileChangeEvent)
*/
public void profileChange(ProblemProfileChangeEvent event) {
if (event.getKey().equals(ProblemProfileChangeEvent.PROBLEM_KEY)) {
IResource resource = (IResource) event.getSource();
IProblemProfile profile = (IProblemProfile) event.getNewValue();
IProblem pp = profile.findProblem(GrepChecker.ID);
System.err.println(pp.getName() + " enabled "+ pp.isEnabled());
System.err.println(pp.getName() + " enabled " + pp.isEnabled());
}
}
}