diff --git a/core/org.eclipse.cdt.core/parser/org/eclipse/cdt/core/index/IIndexManager.java b/core/org.eclipse.cdt.core/parser/org/eclipse/cdt/core/index/IIndexManager.java
index 3e2531e8d3e..6cce732b04c 100644
--- a/core/org.eclipse.cdt.core/parser/org/eclipse/cdt/core/index/IIndexManager.java
+++ b/core/org.eclipse.cdt.core/parser/org/eclipse/cdt/core/index/IIndexManager.java
@@ -1,5 +1,5 @@
/*******************************************************************************
- * Copyright (c) 2006, 2007 Wind River Systems, Inc. and others.
+ * Copyright (c) 2006, 2008 Wind River Systems, Inc. and others.
* All rights reserved. This program and the accompanying materials
* are made available under the terms of the Eclipse Public License v1.0
* which accompanies this distribution, and is available at
@@ -11,6 +11,7 @@
package org.eclipse.cdt.core.index;
+import org.eclipse.cdt.core.CCorePlugin;
import org.eclipse.cdt.core.dom.IPDOMManager;
import org.eclipse.cdt.core.model.ICElement;
import org.eclipse.cdt.core.model.ICProject;
@@ -196,4 +197,14 @@ public interface IIndexManager extends IPDOMManager {
* @since 4.0
*/
public void export(ICProject project, String location, int options, IProgressMonitor monitor) throws CoreException;
+
+ /**
+ * Adds a participant for the indexer-setup
+ */
+ public void addIndexerSetupParticipant(IndexerSetupParticipant participant);
+
+ /**
+ * Removes a participant for the indexer-setup
+ */
+ public void removeIndexerSetupParticipant(IndexerSetupParticipant participant);
}
diff --git a/core/org.eclipse.cdt.core/parser/org/eclipse/cdt/core/index/IndexerSetupParticipant.java b/core/org.eclipse.cdt.core/parser/org/eclipse/cdt/core/index/IndexerSetupParticipant.java
new file mode 100644
index 00000000000..4979d85d225
--- /dev/null
+++ b/core/org.eclipse.cdt.core/parser/org/eclipse/cdt/core/index/IndexerSetupParticipant.java
@@ -0,0 +1,43 @@
+/*******************************************************************************
+ * Copyright (c) 2008 Wind River Systems, Inc. and others.
+ * All rights reserved. This program and the accompanying materials
+ * are made available under the terms of the Eclipse Public License v1.0
+ * which accompanies this distribution, and is available at
+ * http://www.eclipse.org/legal/epl-v10.html
+ *
+ * Contributors:
+ * Markus Schorn - initial API and implementation
+ *******************************************************************************/
+package org.eclipse.cdt.core.index;
+
+import org.eclipse.cdt.core.model.ICProject;
+import org.eclipse.cdt.internal.core.CCoreInternals;
+
+/**
+ * Abstract base class for indexer setup participants. A participant can delay the
+ * setup of the indexer when a project is added to the workspace.
+ */
+public abstract class IndexerSetupParticipant {
+
+ /**
+ * The method will be called before an indexer is set up for a project. If you
+ * return true
the setup will be postponed. You need to call
+ * {@link #notifyIndexerSetup(ICProject)} as soon as this participant no longer
+ * needs to block the indexer setup.
+ *
+ * This method may be called multiple times for the same project.
+ * @param project the project for which the indexer is supposed to be initialized.
+ * @return whether or not to proceed with the indexer setup.
+ */
+ public abstract boolean postponeIndexerSetup(ICProject project);
+
+ /**
+ * Informs the index manager that this participant no longer needs to postpone the
+ * indexer setup for the given project. Depending on the state of other participants
+ * this may trigger the indexer setup.
+ * @param project the project for which the setup no longer needs to be postponed
+ */
+ public void notifyIndexerSetup(ICProject project) {
+ CCoreInternals.getPDOMManager().notifyIndexerSetup(this, project);
+ }
+}
diff --git a/core/org.eclipse.cdt.core/parser/org/eclipse/cdt/internal/core/pdom/CProjectDescriptionListener.java b/core/org.eclipse.cdt.core/parser/org/eclipse/cdt/internal/core/pdom/CProjectDescriptionListener.java
index 70163de9ee7..d3894ef7e58 100644
--- a/core/org.eclipse.cdt.core/parser/org/eclipse/cdt/internal/core/pdom/CProjectDescriptionListener.java
+++ b/core/org.eclipse.cdt.core/parser/org/eclipse/cdt/internal/core/pdom/CProjectDescriptionListener.java
@@ -1,5 +1,5 @@
/*******************************************************************************
- * Copyright (c) 2007 Wind River Systems, Inc. and others.
+ * Copyright (c) 2007, 2008 Wind River Systems, Inc. and others.
* All rights reserved. This program and the accompanying materials
* are made available under the terms of the Eclipse Public License v1.0
* which accompanies this distribution, and is available at
@@ -11,20 +11,34 @@
package org.eclipse.cdt.internal.core.pdom;
+import org.eclipse.cdt.core.index.IndexerSetupParticipant;
import org.eclipse.cdt.core.model.CoreModel;
import org.eclipse.cdt.core.model.ICProject;
import org.eclipse.cdt.core.settings.model.CProjectDescriptionEvent;
import org.eclipse.cdt.core.settings.model.ICConfigurationDescription;
import org.eclipse.cdt.core.settings.model.ICProjectDescription;
import org.eclipse.cdt.core.settings.model.ICProjectDescriptionListener;
+import org.eclipse.cdt.internal.core.settings.model.CProjectDescriptionManager;
import org.eclipse.core.resources.IProject;
public class CProjectDescriptionListener implements ICProjectDescriptionListener {
private PDOMManager fIndexManager;
+ private IndexerSetupParticipant fIndexerSetupParticipant;
public CProjectDescriptionListener(PDOMManager manager) {
fIndexManager= manager;
+ fIndexerSetupParticipant= createIndexerSetupParticipant();
+ manager.addIndexerSetupParticipant(fIndexerSetupParticipant);
+ }
+
+ private IndexerSetupParticipant createIndexerSetupParticipant() {
+ return new IndexerSetupParticipant() {
+ @Override
+ public boolean postponeIndexerSetup(ICProject project) {
+ return !isProjectCreationComplete(project.getProject());
+ }
+ };
}
public void handleEvent(CProjectDescriptionEvent event) {
@@ -34,7 +48,7 @@ public class CProjectDescriptionListener implements ICProjectDescriptionListener
if (completedProjectCreation(old, act)) {
ICProject project= getProject(event);
if (project != null) {
- fIndexManager.addProject(project);
+ fIndexerSetupParticipant.notifyIndexerSetup(project);
}
}
else if (old != null && changedDefaultSettingConfiguration(old, act)) {
@@ -69,6 +83,11 @@ public class CProjectDescriptionListener implements ICProjectDescriptionListener
return null;
}
+ protected boolean isProjectCreationComplete(IProject project) {
+ ICProjectDescription desc= CProjectDescriptionManager.getInstance().getProjectDescription(project.getProject(), false);
+ return !(desc == null || desc.isCdtProjectCreating());
+ }
+
private boolean completedProjectCreation(ICProjectDescription old, ICProjectDescription act) {
return (old == null || old.isCdtProjectCreating()) && !act.isCdtProjectCreating();
}
diff --git a/core/org.eclipse.cdt.core/parser/org/eclipse/cdt/internal/core/pdom/PDOMManager.java b/core/org.eclipse.cdt.core/parser/org/eclipse/cdt/internal/core/pdom/PDOMManager.java
index f845cc0a6ad..bfae97e6ede 100644
--- a/core/org.eclipse.cdt.core/parser/org/eclipse/cdt/internal/core/pdom/PDOMManager.java
+++ b/core/org.eclipse.cdt.core/parser/org/eclipse/cdt/internal/core/pdom/PDOMManager.java
@@ -40,6 +40,7 @@ import org.eclipse.cdt.core.index.IIndexChangeListener;
import org.eclipse.cdt.core.index.IIndexLocationConverter;
import org.eclipse.cdt.core.index.IIndexManager;
import org.eclipse.cdt.core.index.IIndexerStateListener;
+import org.eclipse.cdt.core.index.IndexerSetupParticipant;
import org.eclipse.cdt.core.model.CModelException;
import org.eclipse.cdt.core.model.CoreModel;
import org.eclipse.cdt.core.model.ICContainer;
@@ -50,7 +51,6 @@ import org.eclipse.cdt.core.model.ILanguageMappingChangeListener;
import org.eclipse.cdt.core.model.ITranslationUnit;
import org.eclipse.cdt.core.model.LanguageManager;
import org.eclipse.cdt.core.settings.model.CProjectDescriptionEvent;
-import org.eclipse.cdt.core.settings.model.ICProjectDescription;
import org.eclipse.cdt.core.settings.model.ICProjectDescriptionListener;
import org.eclipse.cdt.internal.core.CCoreInternals;
import org.eclipse.cdt.internal.core.index.IIndexFragment;
@@ -70,7 +70,6 @@ import org.eclipse.cdt.internal.core.pdom.indexer.PDOMRebuildTask;
import org.eclipse.cdt.internal.core.pdom.indexer.PDOMUpdateTask;
import org.eclipse.cdt.internal.core.pdom.indexer.ProjectIndexerInputAdapter;
import org.eclipse.cdt.internal.core.pdom.indexer.TriggerNotificationTask;
-import org.eclipse.cdt.internal.core.settings.model.CProjectDescriptionManager;
import org.eclipse.core.resources.IFolder;
import org.eclipse.core.resources.IProject;
import org.eclipse.core.resources.IResource;
@@ -166,7 +165,7 @@ public class PDOMManager implements IWritableIndexManager, IListener {
private CModelListener fCModelListener= new CModelListener(this);
private ILanguageMappingChangeListener fLanguageChangeListener = new LanguageMappingChangeListener(this);
- private ICProjectDescriptionListener fProjectDescriptionListener= new CProjectDescriptionListener(this);
+ private final ICProjectDescriptionListener fProjectDescriptionListener;
private IndexFactory fIndexFactory= new IndexFactory(this);
private IndexProviderManager fIndexProviderManager = new IndexProviderManager();
@@ -178,13 +177,21 @@ public class PDOMManager implements IWritableIndexManager, IListener {
*/
private HashMap