X-Git-Url: http://git.phpeclipse.com

diff --git a/net.sourceforge.phpeclipse/src/net/sourceforge/phpeclipse/PHPeclipsePlugin.java b/net.sourceforge.phpeclipse/src/net/sourceforge/phpeclipse/PHPeclipsePlugin.java
index 2a2005c..d3a771d 100644
--- a/net.sourceforge.phpeclipse/src/net/sourceforge/phpeclipse/PHPeclipsePlugin.java
+++ b/net.sourceforge.phpeclipse/src/net/sourceforge/phpeclipse/PHPeclipsePlugin.java
@@ -68,6 +68,7 @@ import org.eclipse.core.resources.ISavedState;
 import org.eclipse.core.resources.IWorkspace;
 import org.eclipse.core.resources.IWorkspaceRunnable;
 import org.eclipse.core.resources.ResourcesPlugin;
+import org.eclipse.core.resources.WorkspaceJob;
 import org.eclipse.core.runtime.CoreException;
 import org.eclipse.core.runtime.IAdapterManager;
 import org.eclipse.core.runtime.IConfigurationElement;
@@ -161,42 +162,6 @@ public class PHPeclipsePlugin extends AbstractUIPlugin implements
 	 */
 	private static final String CODE_TEMPLATES_KEY = "net.sourceforge.phpdt.ui.text.custom_code_templates"; //$NON-NLS-1$
 
-	/**
-	 * The key to store whether the legacy templates have been migrated
-	 * 
-	 * @since 3.0
-	 */
-	// private static final String TEMPLATES_MIGRATION_KEY=
-	// "net.sourceforge.phpdt.ui.text.templates_migrated"; //$NON-NLS-1$
-	/**
-	 * The key to store whether the legacy code templates have been migrated
-	 * 
-	 * @since 3.0
-	 */
-	// private static final String CODE_TEMPLATES_MIGRATION_KEY=
-	// "net.sourceforge.phpdt.ui.text.code_templates_migrated";
-	// //$NON-NLS-1$
-	// private static ExternalToolsPlugin externalTools;
-	/**
-	 * The Java virtual machine that we are running on.
-	 */
-	// private static int jvm;
-	// /** MRJ 2.0 */
-	// private static final int MRJ_2_0 = 0;
-	//
-	// /** MRJ 2.1 or later */
-	// private static final int MRJ_2_1 = 1;
-	//
-	// /** Java on Mac OS X 10.0 (MRJ 3.0) */
-	// private static final int MRJ_3_0 = 3;
-	//
-	// /** MRJ 3.1 */
-	// private static final int MRJ_3_1 = 4;
-	//
-	// /** JVM constant for any other platform */
-	// private static final int OTHER = -1;
-	// public static final String PHP_RESOURCES_VIEW_ID = PLUGIN_ID +
-	// ".resourcesview.ViewPHPResources"; //$NON-NLS-1$
 	public static final String PHP_CODING_ACTION_SET_ID = PLUGIN_ID
 			+ ".ui.CodingActionSet"; //$NON-NLS-1$
 
@@ -784,37 +749,8 @@ public class PHPeclipsePlugin extends AbstractUIPlugin implements
 			// store.setDefault(APACHE_RESTART_BACKGROUND, "true");
 		}
 
-		// store.setDefault(SHOW_OUTPUT_IN_CONSOLE, "true");
-		// store.setDefault(PHP_OBFUSCATOR_DEFAULT, "c:\\temp");
-		// if (operatingSystem.equals(Platform.OS_WIN32)) {
-		// store.setDefault(EXTERNAL_BROWSER_PREF, "rundll32
-		// url.dll,FileProtocolHandler {0}");
-		// } else if (operatingSystem.equals(Platform.OS_MACOSX)) {
-		// store.setDefault(PHP_OBFUSCATOR_DEFAULT, "/tmp");
-		// TODO How do we start Safari on Mac OS X ?
-		// store.setDefault(EXTERNAL_BROWSER_PREF, "netscape {0}");
-		// } else {
-		// store.setDefault(PHP_OBFUSCATOR_DEFAULT, "/tmp");
-		// store.setDefault(EXTERNAL_BROWSER_PREF, "netscape {0}");
-		// }
-
-		// store.setDefault(PHP_EXTENSION_PREFS,
-		// "php,php3,php4,php5,phtml,inc,module,class");
-
-		// store.setDefault(PHP_PARSER_DEFAULT, PHP_EXTERNAL_PARSER);
-		// store.setDefault(PHP_INTERNAL_PARSER, "false");
-		// store.setDefault(PHP_EXTERNAL_PARSER, "true");
-		// store.setDefault(PHP_PARSE_ON_SAVE, "true");
-		// show line numbers:
-		// store.setDefault(LINE_NUMBER_RULER, "false");
-		// store.setDefault(FORMATTER_TAB_SIZE, "4");
 		// php syntax highlighting
 		store.setDefault(PHP_USERDEF_XMLFILE, "");
-		// assume there is none chooA
-		// PreferenceConverter.setDefault(store, PHP_MULTILINE_COMMENT,
-		// PHPColorProvider.MULTI_LINE_COMMENT);
-		// PreferenceConverter.setDefault(store, PHP_SINGLELINE_COMMENT,
-		// PHPColorProvider.SINGLE_LINE_COMMENT);
 		PreferenceConverter.setDefault(store, PHP_TAG, PHPColorProvider.TAG);
 		PreferenceConverter.setDefault(store, PHP_KEYWORD,
 				PHPColorProvider.KEYWORD);
@@ -827,11 +763,6 @@ public class PHPeclipsePlugin extends AbstractUIPlugin implements
 		PreferenceConverter.setDefault(store, PHP_CONSTANT,
 				PHPColorProvider.CONSTANT);
 		PreferenceConverter.setDefault(store, PHP_TYPE, PHPColorProvider.TYPE);
-		// PreferenceConverter.setDefault(store, PHP_STRING_DQ,
-		// PHPColorProvider.STRING_DQ);
-		// store.setDefault(PHP_STRING_BOLD_DQ, true);
-		// PreferenceConverter.setDefault(store, PHP_STRING_SQ,
-		// PHPColorProvider.STRING_SQ);
 		PreferenceConverter.setDefault(store, PHP_DEFAULT,
 				PHPColorProvider.DEFAULT);
 		PreferenceConverter.setDefault(store, PHPDOC_KEYWORD,
@@ -857,53 +788,13 @@ public class PHPeclipsePlugin extends AbstractUIPlugin implements
 				new RGB(0, 0, 0));
 		store.setDefault(EDITOR_PHP_BRACE_OPERATOR_BOLD, false);
 		store.setDefault(EDITOR_PHP_BRACE_OPERATOR_ITALIC, false);
-		// PreferenceConverter.setDefault(
-		// store,
-		// PHP_EDITOR_BACKGROUND,
-		// PHPColorProvider.BACKGROUND);
-		// PreferenceConverter.setDefault(
-		// store,
-		// LINKED_POSITION_COLOR,
-		// PHPColorProvider.LINKED_POSITION_COLOR);
-		// PreferenceConverter.setDefault(
-		// store,
-		// LINE_NUMBER_COLOR,
-		// PHPColorProvider.LINE_NUMBER_COLOR);
-		// // set default PHPDoc colors:
-		// PreferenceConverter.setDefault(
-		// store,
-		// PHPDOC_KEYWORD,
-		// PHPColorProvider.PHPDOC_KEYWORD);
-		// PreferenceConverter.setDefault(
-		// store,
-		// PHPDOC_LINK,
-		// PHPColorProvider.PHPDOC_LINK);
-		// PreferenceConverter.setDefault(
-		// store,
-		// PHPDOC_DEFAULT,
-		// PHPColorProvider.PHPDOC_DEFAULT);
-		// PreferenceConverter.setDefault(
-		// store,
-		// PHPDOC_TAG,
-		// PHPColorProvider.PHPDOC_TAG);
-		// store.setDefault(PREFERENCE_COLOR_BACKGROUND_SYSTEM_DEFAULT, "true");
-		// PreferenceConverter.setDefault(
-		// store,
-		// PREFERENCE_COLOR_BACKGROUND,
-		// PHPColorProvider.BACKGROUND_COLOR);
-		// language stuff
-		// store.setDefault(RESOURCE_BUNDLE, LANGUAGE_DEFAULT);
-		// store.setDefault(RESOURCE_BUNDLE_EN_GB, "true");
-		// store.setDefault(RESOURCE_BUNDLE_DE, "false");
-		// store.setDefault(RESOURCE_BUNDLE_FR, "false");
-		// store.setDefault(RESOURCE_BUNDLE_ES, "false");
-		// TemplatePreferencePage.initDefaults(store);
+
 		// this will initialize the static fields in the syntaxrdr class
 		new PHPSyntaxRdr();
 		JavaCore.initializeDefaultPluginPreferences();
 		PreferenceConstants.initializeDefaultValues(store);
 		// externalTools.initializeDefaultPreferences(store);
-		MarkerAnnotationPreferences.initializeDefaultValues(store);
+		// MarkerAnnotationPreferences.initializeDefaultValues(store);
 	}
 
 	private IWorkbenchPage internalGetActivePage() {
@@ -936,7 +827,7 @@ public class PHPeclipsePlugin extends AbstractUIPlugin implements
 		IWorkbenchPage page = window.getActivePage();
 		IPath path = new Path(filename);
 		// If the file exists in the workspace, open it
-		IFile file = getWorkspace().getRoot().getFileForLocation(path);
+		IFile file = getWorkspace().getRoot().getFile(path);
 		IEditorPart editor;
 		ITextEditor textEditor;
 		if (file != null && file.exists()) {
@@ -1103,51 +994,6 @@ public class PHPeclipsePlugin extends AbstractUIPlugin implements
 	}
 
 	/**
-	 * @see org.eclipse.ui.plugin.AbstractUIPlugin#shutdown()
-	 */
-	// public void shutdown() throws CoreException {
-	// // moved down (see below):
-	// // super.shutdown();
-	// // externalTools.shutDown();
-	// ColorManager.getDefault().dispose();
-	// // save the information from the php index files if necessary
-	// Collection collection = fIndexManagerMap.values();
-	// Iterator iterator = collection.iterator();
-	// IdentifierIndexManager indexManager = null;
-	// while (iterator.hasNext()) {
-	// indexManager = (IdentifierIndexManager) iterator.next();
-	// indexManager.writeFile();
-	// }
-	// if (fImageDescriptorRegistry != null)
-	// fImageDescriptorRegistry.dispose();
-	// // unregisterAdapters();
-	// super.shutdown();
-	// if (fWorkingCopyManager != null) {
-	// fWorkingCopyManager.shutdown();
-	// fWorkingCopyManager = null;
-	// }
-	// if (fCompilationUnitDocumentProvider != null) {
-	// fCompilationUnitDocumentProvider.shutdown();
-	// fCompilationUnitDocumentProvider = null;
-	// }
-	// if (fJavaTextTools != null) {
-	// fJavaTextTools.dispose();
-	// fJavaTextTools = null;
-	// }
-	// // JavaDocLocations.shutdownJavadocLocations();
-	// //
-	// //
-	// JFaceResources.getFontRegistry().removeListener(fFontPropertyChangeListener);
-	// // begin JavaCore#shutdown()
-	// //savePluginPreferences();
-	// savePluginPreferences();
-	// IWorkspace workspace = ResourcesPlugin.getWorkspace();
-	// workspace.removeResourceChangeListener(JavaModelManager.getJavaModelManager().deltaState);
-	// workspace.removeSaveParticipant(this);
-	// ((JavaModelManager) JavaModelManager.getJavaModelManager()).shutdown();
-	// // end JavaCore#shutdown()
-	// }
-	/**
 	 * Installs backwards compatibility for the preference store.
 	 */
 	private void installPreferenceStoreBackwardsCompatibility() {
@@ -1193,45 +1039,6 @@ public class PHPeclipsePlugin extends AbstractUIPlugin implements
 		};
 		JFaceResources.getFontRegistry().addListener(
 				fFontPropertyChangeListener);
-
-		/*
-		 * Backwards compatibility: propagate the Java editor tab width from a
-		 * pre-3.0 plug-in to the new preference key. This is done only once.
-		 */
-		// final String oldTabWidthKey = PreferenceConstants.EDITOR_TAB_WIDTH;
-		// final String newTabWidthKey =
-		// AbstractDecoratedTextEditorPreferenceConstants.EDITOR_TAB_WIDTH;
-		// String tabWidthPropagatedKey = "tabWidthPropagated"; //$NON-NLS-1$
-		// if (getPreferenceStore().contains(oldTabWidthKey) &&
-		// !getPreferenceStore().isDefault(oldTabWidthKey)) {
-		// if (!getPreferenceStore().getBoolean(tabWidthPropagatedKey))
-		// getPreferenceStore().setValue(newTabWidthKey,
-		// getPreferenceStore().getInt(oldTabWidthKey));
-		// }
-		// getPreferenceStore().setValue(tabWidthPropagatedKey, true);
-		//
-		// /*
-		// * Backwards compatibility: set the Java editor tab width in this
-		// plug-in's preference store with the old key to let older
-		// * versions access it. Since 3.0 the tab width is managed by the
-		// extended texteditor and uses a new key.
-		// */
-		// getPreferenceStore().putValue(oldTabWidthKey,
-		// getPreferenceStore().getString(newTabWidthKey));
-		// fPropertyChangeListener = new IPropertyChangeListener() {
-		// public void propertyChange(PropertyChangeEvent event) {
-		// if (newTabWidthKey.equals(event.getProperty()))
-		// getPreferenceStore().putValue(oldTabWidthKey,
-		// getPreferenceStore().getString(newTabWidthKey));
-		// }
-		// };
-		// getPreferenceStore().addPropertyChangeListener(fPropertyChangeListener);
-		/*
-		 * Backward compatibility for the refactoring preference key.
-		 */
-		// getPreferenceStore().setValue(
-		// PreferenceConstants.REFACTOR_ERROR_PAGE_SEVERITY_THRESHOLD,
-		// RefactoringCore.getConditionCheckingFailedSeverity());
 	}
 
 	/**
@@ -1256,7 +1063,6 @@ public class PHPeclipsePlugin extends AbstractUIPlugin implements
 			modelManager.configurePluginDebugOptions();
 
 			// request state folder creation (workaround 19885)
-			// JavaCore.getPlugin().getStateLocation();
 			getStateLocation();
 			// retrieve variable values
 			PHPeclipsePlugin.getDefault().getPluginPreferences()
@@ -1272,39 +1078,54 @@ public class PHPeclipsePlugin extends AbstractUIPlugin implements
 							| IResourceChangeEvent.PRE_DELETE
 							| IResourceChangeEvent.PRE_CLOSE);
 
-			// startIndexing();
 			ISavedState savedState = workspace.addSaveParticipant(
 					PHPeclipsePlugin.this, modelManager);
 
 			// process deltas since last activated in indexer thread so that
 			// indexes are up-to-date.
 			// see https://bugs.eclipse.org/bugs/show_bug.cgi?id=38658
-			Job processSavedState = new Job(Util.bind("savedState.jobName")) { //$NON-NLS-1$
-				protected IStatus run(IProgressMonitor monitor) {
-					try {
-						// add save participant and process delta atomically
-						// see
-						// https://bugs.eclipse.org/bugs/show_bug.cgi?id=59937
-						workspace.run(new IWorkspaceRunnable() {
-							public void run(IProgressMonitor progress)
-									throws CoreException {
-								ISavedState savedState = workspace
-										.addSaveParticipant(
-												PHPeclipsePlugin.this,
-												modelManager);
-								if (savedState != null) {
-									// the event type coming from the saved
-									// state is always POST_AUTO_BUILD
-									// force it to be POST_CHANGE so that the
-									// delta processor can handle it
-									modelManager.deltaState.getDeltaProcessor().overridenEventType = IResourceChangeEvent.POST_CHANGE;
-									savedState
-											.processResourceChangeEvents(modelManager.deltaState);
-								}
-							}
-						}, monitor);
-					} catch (CoreException e) {
-						return e.getStatus();
+// This causes timeout at EclipseLazyStarter
+//			Job processSavedState = new Job(Util.bind("savedState.jobName")) { //$NON-NLS-1$
+//				protected IStatus run(IProgressMonitor monitor) {
+//					try {
+//						// add save participant and process delta atomically
+//						// see
+//						// https://bugs.eclipse.org/bugs/show_bug.cgi?id=59937
+//						workspace.run(new IWorkspaceRunnable() {
+//							public void run(IProgressMonitor progress)
+//									throws CoreException {
+//								ISavedState savedState = workspace
+//										.addSaveParticipant(
+//												PHPeclipsePlugin.this,
+//												modelManager);
+//								if (savedState != null) {
+//									// the event type coming from the saved
+//									// state is always POST_AUTO_BUILD
+//									// force it to be POST_CHANGE so that the
+//									// delta processor can handle it
+//									modelManager.deltaState.getDeltaProcessor().overridenEventType = IResourceChangeEvent.POST_CHANGE;
+//									savedState
+//											.processResourceChangeEvents(modelManager.deltaState);
+//								}
+//							}
+//						}, monitor);
+//					} catch (CoreException e) {
+//						return e.getStatus();
+//					}
+//					return Status.OK_STATUS;
+//				}
+//			};
+// Replace Job + IWorkspace.run() to WorkspaceJob
+			WorkspaceJob processSavedState = new WorkspaceJob(
+					Util.bind("savedState.jobName")) { //$NON-NLS-1$
+				public IStatus runInWorkspace(IProgressMonitor monitor)
+						throws CoreException {
+					ISavedState savedState = workspace.addSaveParticipant(
+							PHPeclipsePlugin.this, modelManager);
+					if (savedState != null) {
+						modelManager.deltaState.getDeltaProcessor().overridenEventType
+								= IResourceChangeEvent.POST_CHANGE;
+						savedState.processResourceChangeEvents(modelManager.deltaState);
 					}
 					return Status.OK_STATUS;
 				}
@@ -1335,109 +1156,21 @@ public class PHPeclipsePlugin extends AbstractUIPlugin implements
 
 	}
 
-	// registerAdapters();
-	//
-	// // externalTools.startUp();
-	// getStandardDisplay().asyncExec(new Runnable() {
-	// public void run() {
-	// //initialize the variable context manager
-	// VariableContextManager.getDefault();
-	// }
-	// });
-	//
-	// // if (USE_WORKING_COPY_OWNERS) {
-	// WorkingCopyOwner.setPrimaryBufferProvider(new WorkingCopyOwner() {
-	// public IBuffer createBuffer(ICompilationUnit workingCopy) {
-	// ICompilationUnit original = workingCopy.getPrimary();
-	// IResource resource = original.getResource();
-	// if (resource instanceof IFile)
-	// return new DocumentAdapter(workingCopy, (IFile) resource);
-	// return DocumentAdapter.NULL;
-	// }
-	// });
-	// // }
-
-	// installPreferenceStoreBackwardsCompatibility();
-
-	// AllTypesCache.initialize();
-
-	// Initialize AST provider
-	// getASTProvider();
-	// }
-
-	// public void startup() throws CoreException {
-	// super.startup();
-	// // begin JavaCore.startup();
-	// JavaModelManager manager = JavaModelManager.getJavaModelManager();
-	// try {
-	// manager.configurePluginDebugOptions();
-	// // request state folder creation (workaround 19885)
-	// // JavaCore.getPlugin().getStateLocation();
-	// getStateLocation();
-	// // retrieve variable values
-	// //
-	// JavaCore.getPlugin().getPluginPreferences().addPropertyChangeListener(new
-	// // JavaModelManager.PluginPreferencesListener());
-	// getPluginPreferences().addPropertyChangeListener(
-	// new JavaModelManager.PluginPreferencesListener());
-	// // TODO temp-del
-	// // manager.loadVariablesAndContainers();
-	// final IWorkspace workspace = ResourcesPlugin.getWorkspace();
-	// workspace.addResourceChangeListener(
-	// manager.deltaState,
-	// IResourceChangeEvent.PRE_BUILD
-	// | IResourceChangeEvent.POST_BUILD
-	// | IResourceChangeEvent.POST_CHANGE
-	// | IResourceChangeEvent.PRE_DELETE
-	// | IResourceChangeEvent.PRE_CLOSE);
-	// // startIndexing();
-	// workspace.addSaveParticipant(PHPeclipsePlugin.getDefault(), manager);
-	// } catch (CoreException e) {
-	// } catch (RuntimeException e) {
-	// manager.shutdown();
-	// throw e;
-	// }
-	// // end JavaCore.startup();
-	// IAdapterManager platformManager = Platform.getAdapterManager();
-	// platformManager.registerAdapters(new PHPElementAdapterFactory(),
-	// PHPElement.class);
-	// platformManager.registerAdapters(new ResourceAdapterFactory(),
-	// IResource.class);
-	// // externalTools.startUp();
-	// getStandardDisplay().asyncExec(new Runnable() {
-	// public void run() {
-	// //initialize the variable context manager
-	// VariableContextManager.getDefault();
-	// }
-	// });
-	// }
-
 	private void registerAdapters() {
 		fJavaElementAdapterFactory = new JavaElementAdapterFactory();
-		// fMarkerAdapterFactory= new MarkerAdapterFactory();
-		// fEditorInputAdapterFactory= new EditorInputAdapterFactory();
 		fResourceAdapterFactory = new ResourceAdapterFactory();
-		// fLogicalPackageAdapterFactory= new LogicalPackageAdapterFactory();
 
 		IAdapterManager manager = Platform.getAdapterManager();
 		manager
 				.registerAdapters(fJavaElementAdapterFactory,
 						IJavaElement.class);
-		// manager.registerAdapters(fMarkerAdapterFactory, IMarker.class);
-		// manager.registerAdapters(fEditorInputAdapterFactory,
-		// IEditorInput.class);
 		manager.registerAdapters(fResourceAdapterFactory, IResource.class);
-		// manager.registerAdapters(fLogicalPackageAdapterFactory,
-		// LogicalPackage.class);
 	}
 
 	private void unregisterAdapters() {
 		IAdapterManager manager = Platform.getAdapterManager();
 		manager.unregisterAdapters(fJavaElementAdapterFactory);
-		// manager.unregisterAdapters(fMarkerAdapterFactory);
-		// manager.unregisterAdapters(fEditorInputAdapterFactory);
 		manager.unregisterAdapters(fResourceAdapterFactory);
-		// manager.unregisterAdapters(fLogicalPackageAdapterFactory);
 	}
 
 	/**
@@ -1592,20 +1325,9 @@ public class PHPeclipsePlugin extends AbstractUIPlugin implements
 	 */
 	public TemplateStore getTemplateStore() {
 		if (fTemplateStore == null) {
-			// boolean alreadyMigrated=
-			// getPreferenceStore().getBoolean(TEMPLATES_MIGRATION_KEY);
-			// if (alreadyMigrated)
 			fTemplateStore = new ContributionTemplateStore(
 					getTemplateContextRegistry(), getPreferenceStore(),
 					TEMPLATES_KEY);
-			// else {
-			// fTemplateStore= new
-			// CompatibilityTemplateStore(getTemplateContextRegistry(),
-			// getPreferenceStore(), TEMPLATES_KEY,
-			// Templates.getInstance());
-			// getPreferenceStore().setValue(TEMPLATES_MIGRATION_KEY, true);
-			// }
-
 			try {
 				fTemplateStore.load();
 			} catch (IOException e) {
@@ -1643,31 +1365,14 @@ public class PHPeclipsePlugin extends AbstractUIPlugin implements
 	 */
 	public TemplateStore getCodeTemplateStore() {
 		if (fCodeTemplateStore == null) {
-			// boolean alreadyMigrated=
-			// getPreferenceStore().getBoolean(CODE_TEMPLATES_MIGRATION_KEY);
-			// if (alreadyMigrated)
 			fCodeTemplateStore = new ContributionTemplateStore(
 					getCodeTemplateContextRegistry(), getPreferenceStore(),
 					CODE_TEMPLATES_KEY);
-			// else {
-			// fCodeTemplateStore= new
-			// CompatibilityTemplateStore(getCodeTemplateContextRegistry(),
-			// getPreferenceStore(),
-			// CODE_TEMPLATES_KEY, CodeTemplates.getInstance());
-			// getPreferenceStore().setValue(CODE_TEMPLATES_MIGRATION_KEY,
-			// true);
-			// }
-
 			try {
 				fCodeTemplateStore.load();
 			} catch (IOException e) {
 				log(e);
 			}
-
-			// compatibility / bug fixing code for duplicated templates
-			// TODO remove for 3.0
-			// CompatibilityTemplateStore.pruneDuplicates(fCodeTemplateStore,
-			// true);
 		}
 
 		return fCodeTemplateStore;