Skip to main content
summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorDavid Inglis2004-02-19 19:25:40 +0000
committerDavid Inglis2004-02-19 19:25:40 +0000
commit009c9421a2d0a035cf026879ecb65dbd3d586fcd (patch)
treeaf7ce10a04ac8f6dc617a6aa39cdbc479f739d91
parentedb523de6f9a32058b1001cf06ee4250456d5016 (diff)
downloadorg.eclipse.cdt-009c9421a2d0a035cf026879ecb65dbd3d586fcd.tar.gz
org.eclipse.cdt-009c9421a2d0a035cf026879ecb65dbd3d586fcd.tar.xz
org.eclipse.cdt-009c9421a2d0a035cf026879ecb65dbd3d586fcd.zip
fixed bug# 52490
-rw-r--r--build/org.eclipse.cdt.make.core/src/org/eclipse/cdt/make/internal/core/MakeTargetManager.java28
-rw-r--r--build/org.eclipse.cdt.make.core/src/org/eclipse/cdt/make/internal/core/ProjectTargets.java7
2 files changed, 20 insertions, 15 deletions
diff --git a/build/org.eclipse.cdt.make.core/src/org/eclipse/cdt/make/internal/core/MakeTargetManager.java b/build/org.eclipse.cdt.make.core/src/org/eclipse/cdt/make/internal/core/MakeTargetManager.java
index 97742338b44..0739f8617df 100644
--- a/build/org.eclipse.cdt.make.core/src/org/eclipse/cdt/make/internal/core/MakeTargetManager.java
+++ b/build/org.eclipse.cdt.make.core/src/org/eclipse/cdt/make/internal/core/MakeTargetManager.java
@@ -61,12 +61,12 @@ public class MakeTargetManager implements IMakeTargetManager, IResourceChangeLis
public IMakeTarget createTarget(IProject project, String name, String targetBuilderID) throws CoreException {
return new MakeTarget(this, project, targetBuilderID, name);
}
-
+
public void addTarget(IContainer container, IMakeTarget target) throws CoreException {
if (container instanceof IWorkspaceRoot) {
throw new CoreException(new Status(IStatus.ERROR, MakeCorePlugin.getUniqueIdentifier(), -1, MakeCorePlugin.getResourceString("MakeTargetManager.add_to_workspace_root"), null)); //$NON-NLS-1$
}
- if ( target.getContainer() != null) {
+ if (target.getContainer() != null) {
throw new CoreException(new Status(IStatus.ERROR, MakeCorePlugin.getUniqueIdentifier(), -1, MakeCorePlugin.getResourceString("MakeTargetManager.add_temporary_target"), null)); //$NON-NLS-1$
}
IProject project = container.getProject();
@@ -74,8 +74,8 @@ public class MakeTargetManager implements IMakeTargetManager, IResourceChangeLis
if (projectTargets == null) {
projectTargets = readTargets(project);
}
- ((MakeTarget)target).setContainer(container);
- projectTargets.add((MakeTarget)target);
+ ((MakeTarget) target).setContainer(container);
+ projectTargets.add((MakeTarget) target);
writeTargets(projectTargets);
notifyListeners(new MakeTargetEvent(this, MakeTargetEvent.TARGET_ADD, target));
}
@@ -86,9 +86,10 @@ public class MakeTargetManager implements IMakeTargetManager, IResourceChangeLis
if (projectTargets == null) {
projectTargets = readTargets(project);
}
- projectTargets.remove(target);
- writeTargets(projectTargets);
- notifyListeners(new MakeTargetEvent(this, MakeTargetEvent.TARGET_REMOVED, target));
+ if (projectTargets.remove(target)) {
+ writeTargets(projectTargets);
+ notifyListeners(new MakeTargetEvent(this, MakeTargetEvent.TARGET_REMOVED, target));
+ }
}
public void renameTarget(IMakeTarget target, String name) throws CoreException {
@@ -204,7 +205,7 @@ public class MakeTargetManager implements IMakeTargetManager, IResourceChangeLis
int flags = delta.getFlags();
int deltaKind = delta.getKind();
if (deltaKind == IResourceDelta.ADDED) {
- if (hasTargetBuilder(project)) {
+ if (hasTargetBuilder(project) && !fProjects.contains(project)) {
fProjects.add(project);
notifyListeners(new MakeTargetEvent(MakeTargetManager.this, MakeTargetEvent.PROJECT_ADDED, project));
}
@@ -240,7 +241,9 @@ public class MakeTargetManager implements IMakeTargetManager, IResourceChangeLis
}
protected void writeTargets(ProjectTargets projectTargets) throws CoreException {
- IPath targetFilePath = MakeCorePlugin.getDefault().getStateLocation().append(projectTargets.getProject().getName()).addFileExtension(TARGETS_EXT);
+ IPath targetFilePath =
+ MakeCorePlugin.getDefault().getStateLocation().append(projectTargets.getProject().getName()).addFileExtension(
+ TARGETS_EXT);
File targetFile = targetFilePath.toFile();
try {
FileOutputStream file = new FileOutputStream(targetFile);
@@ -253,7 +256,8 @@ public class MakeTargetManager implements IMakeTargetManager, IResourceChangeLis
}
protected ProjectTargets readTargets(IProject project) {
- IPath targetFilePath = MakeCorePlugin.getDefault().getStateLocation().append(project.getName()).addFileExtension(TARGETS_EXT);
+ IPath targetFilePath =
+ MakeCorePlugin.getDefault().getStateLocation().append(project.getName()).addFileExtension(TARGETS_EXT);
File targetFile = targetFilePath.toFile();
ProjectTargets projectTargets = null;
if (targetFile.exists()) {
@@ -262,8 +266,8 @@ public class MakeTargetManager implements IMakeTargetManager, IResourceChangeLis
} catch (FileNotFoundException e) {
}
}
- if ( projectTargets == null) {
- projectTargets = new ProjectTargets(this, project);
+ if (projectTargets == null) {
+ projectTargets = new ProjectTargets(this, project);
}
projectMap.put(project, projectTargets);
return projectTargets;
diff --git a/build/org.eclipse.cdt.make.core/src/org/eclipse/cdt/make/internal/core/ProjectTargets.java b/build/org.eclipse.cdt.make.core/src/org/eclipse/cdt/make/internal/core/ProjectTargets.java
index c3fe5d7391c..a78c002e063 100644
--- a/build/org.eclipse.cdt.make.core/src/org/eclipse/cdt/make/internal/core/ProjectTargets.java
+++ b/build/org.eclipse.cdt.make.core/src/org/eclipse/cdt/make/internal/core/ProjectTargets.java
@@ -172,15 +172,16 @@ public class ProjectTargets {
return false;
}
- public void remove(IMakeTarget target) {
+ public boolean remove(IMakeTarget target) {
ArrayList list = (ArrayList) targetMap.get(target.getContainer());
if (list == null || !list.contains(target)) {
- return;
+ return false;
}
- list.remove(target);
+ boolean found = list.remove(target);
if (list.size() == 0) {
targetMap.remove(list);
}
+ return found;
}
public IProject getProject() {

Back to the top