+++ /dev/null
-/*******************************************************************************
- * Copyright (c) 2000, 2003 IBM Corporation and others.
- * All rights reserved. This program and the accompanying materials
- * are made available under the terms of the Common Public License v1.0
- * which accompanies this distribution, and is available at
- * http://www.eclipse.org/legal/cpl-v10.html
- *
- * Contributors:
- * IBM Corporation - initial API and implementation
- *******************************************************************************/
-package net.sourceforge.phpdt.ui.wizards;
-
-import net.sourceforge.phpdt.core.IJavaElement;
-import net.sourceforge.phpdt.core.IJavaProject;
-import net.sourceforge.phpdt.core.IPackageFragmentRoot;
-import net.sourceforge.phpdt.core.JavaCore;
-import net.sourceforge.phpdt.core.JavaModelException;
-// incastrix
-//import net.sourceforge.phpdt.externaltools.internal.ui.StatusInfo;
-import net.sourceforge.phpeclipse.ui.StatusInfo;
-import net.sourceforge.phpdt.internal.ui.viewsupport.IViewPartInputProvider;
-import net.sourceforge.phpdt.internal.ui.wizards.NewWizardMessages;
-import net.sourceforge.phpdt.internal.ui.wizards.dialogfields.DialogField;
-import net.sourceforge.phpdt.internal.ui.wizards.dialogfields.IDialogFieldListener;
-import net.sourceforge.phpdt.internal.ui.wizards.dialogfields.IStringButtonAdapter;
-import net.sourceforge.phpdt.internal.ui.wizards.dialogfields.LayoutUtil;
-import net.sourceforge.phpdt.internal.ui.wizards.dialogfields.StringButtonDialogField;
-import net.sourceforge.phpeclipse.PHPeclipsePlugin;
-import net.sourceforge.phpeclipse.ui.WebUI;
-
-import org.eclipse.core.resources.IProject;
-import org.eclipse.core.resources.IResource;
-import org.eclipse.core.resources.IWorkspaceRoot;
-import org.eclipse.core.resources.ResourcesPlugin;
-import org.eclipse.core.runtime.IAdaptable;
-import org.eclipse.core.runtime.IPath;
-import org.eclipse.core.runtime.IStatus;
-import org.eclipse.core.runtime.Path;
-import org.eclipse.jface.viewers.IStructuredSelection;
-import org.eclipse.swt.widgets.Composite;
-import org.eclipse.ui.IWorkbenchPart;
-import org.eclipse.ui.views.contentoutline.ContentOutline;
-
-/**
- * Wizard page that acts as a base class for wizard pages that create new Java
- * elements. The class provides a input field for source folders (called
- * container in this class) and API to validate the enter source folder name.
- *
- * @since 2.0
- */
-public abstract class NewContainerWizardPage extends NewElementWizardPage {
-
- /** Id of the container field */
- protected static final String CONTAINER = "NewContainerWizardPage.container"; //$NON-NLS-1$
-
- /** The status of the last validation. */
- protected IStatus fContainerStatus;
-
- private StringButtonDialogField fContainerDialogField;
-
- /*
- * package fragment root corresponding to the input type (can be null)
- */
- private IPackageFragmentRoot fCurrRoot;
-
- private IWorkspaceRoot fWorkspaceRoot;
-
- /**
- * Create a new <code>NewContainerWizardPage</code>
- *
- * @param name
- * the wizard page's name
- */
- public NewContainerWizardPage(String name) {
- super(name);
- fWorkspaceRoot = ResourcesPlugin.getWorkspace().getRoot();
- ContainerFieldAdapter adapter = new ContainerFieldAdapter();
-
- fContainerDialogField = new StringButtonDialogField(adapter);
- fContainerDialogField.setDialogFieldListener(adapter);
- fContainerDialogField.setLabelText(NewWizardMessages
- .getString("NewContainerWizardPage.container.label")); //$NON-NLS-1$
- fContainerDialogField.setButtonLabel(NewWizardMessages
- .getString("NewContainerWizardPage.container.button")); //$NON-NLS-1$
-
- fContainerStatus = new StatusInfo();
- fCurrRoot = null;
- }
-
- /**
- * Initializes the source folder field with a valid package fragement root.
- * The package fragement root is computed from the given Java element.
- *
- * @param elem
- * the Java element used to compute the initial package fragment
- * root used as the source folder
- */
- protected void initContainerPage(IJavaElement elem) {
- IPackageFragmentRoot initRoot = null;
- // if (elem != null) {
- // initRoot= JavaModelUtil.getPackageFragmentRoot(elem);
- // if (initRoot == null || initRoot.isArchive()) {
- // IJavaProject jproject= elem.getJavaProject();
- // if (jproject != null) {
- // try {
- // initRoot= null;
- // if (jproject.exists()) {
- // IPackageFragmentRoot[] roots= jproject.getPackageFragmentRoots();
- // for (int i= 0; i < roots.length; i++) {
- // if (roots[i].getKind() == IPackageFragmentRoot.K_SOURCE) {
- // initRoot= roots[i];
- // break;
- // }
- // }
- // }
- // } catch (JavaModelException e) {
- // PHPeclipsePlugin.log(e);
- // }
- // if (initRoot == null) {
- // initRoot= jproject.getPackageFragmentRoot(jproject.getResource());
- // }
- // }
- // }
- // }
- // setPackageFragmentRoot(initRoot, true);
- }
-
- /**
- * Utility method to inspect a selection to find a Java element.
- *
- * @param selection
- * the selection to be inspected
- * @return a Java element to be used as the initial selection, or
- * <code>null</code>, if no Java element exists in the given
- * selection
- */
- protected IJavaElement getInitialJavaElement(IStructuredSelection selection) {
- IJavaElement jelem = null;
- if (selection != null && !selection.isEmpty()) {
- Object selectedElement = selection.getFirstElement();
- if (selectedElement instanceof IAdaptable) {
- IAdaptable adaptable = (IAdaptable) selectedElement;
-
- jelem = (IJavaElement) adaptable.getAdapter(IJavaElement.class);
- if (jelem == null) {
- IResource resource = (IResource) adaptable
- .getAdapter(IResource.class);
- if (resource != null
- && resource.getType() != IResource.ROOT) {
- while (jelem == null
- && resource.getType() != IResource.PROJECT) {
- resource = resource.getParent();
- jelem = (IJavaElement) resource
- .getAdapter(IJavaElement.class);
- }
- if (jelem == null) {
- jelem = JavaCore.create(resource); // java project
- }
- }
- }
- }
- }
- if (jelem == null) {
- IWorkbenchPart part = WebUI.getActivePage()
- .getActivePart();
- if (part instanceof ContentOutline) {
- part = WebUI.getActivePage().getActiveEditor();
- }
-
- if (part instanceof IViewPartInputProvider) {
- Object elem = ((IViewPartInputProvider) part)
- .getViewPartInput();
- if (elem instanceof IJavaElement) {
- jelem = (IJavaElement) elem;
- }
- }
- }
-
- if (jelem == null || jelem.getElementType() == IJavaElement.JAVA_MODEL) {
- try {
- IJavaProject[] projects = JavaCore.create(getWorkspaceRoot())
- .getJavaProjects();
- if (projects.length == 1) {
- jelem = projects[0];
- }
- } catch (JavaModelException e) {
- PHPeclipsePlugin.log(e);
- }
- }
- return jelem;
- }
-
- /**
- * Returns the recommended maximum width for text fields (in pixels). This
- * method requires that createContent has been called before this method is
- * call. Subclasses may override to change the maximum width for text
- * fields.
- *
- * @return the recommended maximum width for text fields.
- */
- protected int getMaxFieldWidth() {
- return convertWidthInCharsToPixels(40);
- }
-
- /**
- * Creates the necessary controls (label, text field and browse button) to
- * edit the source folder location. The method expects that the parent
- * composite uses a <code>GridLayout</code> as its layout manager and that
- * the grid layout has at least 3 columns.
- *
- * @param parent
- * the parent composite
- * @param nColumns
- * the number of columns to span. This number must be greater or
- * equal three
- */
- protected void createContainerControls(Composite parent, int nColumns) {
- fContainerDialogField.doFillIntoGrid(parent, nColumns);
- LayoutUtil.setWidthHint(fContainerDialogField.getTextControl(null),
- getMaxFieldWidth());
- }
-
- /**
- * Sets the focus to the source folder's text field.
- */
- protected void setFocusOnContainer() {
- fContainerDialogField.setFocus();
- }
-
- // -------- ContainerFieldAdapter --------
-
- private class ContainerFieldAdapter implements IStringButtonAdapter,
- IDialogFieldListener {
-
- // -------- IStringButtonAdapter
- public void changeControlPressed(DialogField field) {
- containerChangeControlPressed(field);
- }
-
- // -------- IDialogFieldListener
- public void dialogFieldChanged(DialogField field) {
- containerDialogFieldChanged(field);
- }
- }
-
- private void containerChangeControlPressed(DialogField field) {
- // take the current jproject as init element of the dialog
- // IPackageFragmentRoot root= getPackageFragmentRoot();
- // root= chooseSourceContainer(root);
- // if (root != null) {
- // setPackageFragmentRoot(root, true);
- // }
- }
-
- private void containerDialogFieldChanged(DialogField field) {
- if (field == fContainerDialogField) {
- fContainerStatus = containerChanged();
- }
- // tell all others
- handleFieldChanged(CONTAINER);
- }
-
- // ----------- validation ----------
-
- /**
- * This method is a hook which gets called after the source folder's text
- * input field has changed. This default implementation updates the model
- * and returns an error status. The underlying model is only valid if the
- * returned status is OK.
- *
- * @return the model's error status
- */
- protected IStatus containerChanged() {
- StatusInfo status = new StatusInfo();
-
- fCurrRoot = null;
- String str = getPackageFragmentRootText();
- if (str.length() == 0) {
- status
- .setError(NewWizardMessages
- .getString("NewContainerWizardPage.error.EnterContainerName")); //$NON-NLS-1$
- return status;
- }
- IPath path = new Path(str);
- IResource res = fWorkspaceRoot.findMember(path);
- if (res != null) {
- int resType = res.getType();
- if (resType == IResource.PROJECT || resType == IResource.FOLDER) {
- IProject proj = res.getProject();
- if (!proj.isOpen()) {
- status
- .setError(NewWizardMessages
- .getFormattedString(
- "NewContainerWizardPage.error.ProjectClosed", proj.getFullPath().toString())); //$NON-NLS-1$
- return status;
- }
- IJavaProject jproject = JavaCore.create(proj);
- // fCurrRoot= jproject.getPackageFragmentRoot(res);
- // if (res.exists()) {
- // try {
- // if (!proj.hasNature(JavaCore.NATURE_ID)) {
- // if (resType == IResource.PROJECT) {
- // status.setError(NewWizardMessages.getString("NewContainerWizardPage.warning.NotAJavaProject"));
- // //$NON-NLS-1$
- // } else {
- // status.setWarning(NewWizardMessages.getString("NewContainerWizardPage.warning.NotInAJavaProject"));
- // //$NON-NLS-1$
- // }
- // return status;
- // }
- // } catch (CoreException e) {
- // status.setWarning(NewWizardMessages.getString("NewContainerWizardPage.warning.NotAJavaProject"));
- // //$NON-NLS-1$
- // }
- // if (!jproject.isOnClasspath(fCurrRoot)) {
- // status.setWarning(NewWizardMessages.getFormattedString("NewContainerWizardPage.warning.NotOnClassPath",
- // str)); //$NON-NLS-1$
- // }
- // if (fCurrRoot.isArchive()) {
- // status.setError(NewWizardMessages.getFormattedString("NewContainerWizardPage.error.ContainerIsBinary",
- // str)); //$NON-NLS-1$
- // return status;
- // }
- // }
- return status;
- } else {
- status.setError(NewWizardMessages.getFormattedString(
- "NewContainerWizardPage.error.NotAFolder", str)); //$NON-NLS-1$
- return status;
- }
- } else {
- status.setError(NewWizardMessages.getFormattedString(
- "NewContainerWizardPage.error.ContainerDoesNotExist", str)); //$NON-NLS-1$
- return status;
- }
- }
-
- // -------- update message ----------------
-
- /**
- * Hook method that gets called when a field on this page has changed. For
- * this page the method gets called when the source folder field changes.
- * <p>
- * Every sub type is responsible to call this method when a field on its
- * page has changed. Subtypes override (extend) the method to add
- * verification when a own field has a dependency to an other field. For
- * example the class name input must be verified again when the package
- * field changes (check for duplicated class names).
- *
- * @param fieldName
- * The name of the field that has changed (field id). For the
- * source folder the field id is <code>CONTAINER</code>
- */
- protected void handleFieldChanged(String fieldName) {
- }
-
- // ---- get ----------------
-
- /**
- * Returns the workspace root.
- *
- * @return the workspace root
- */
- protected IWorkspaceRoot getWorkspaceRoot() {
- return fWorkspaceRoot;
- }
-
- /**
- * Returns the <code>IPackageFragmentRoot</code> that corresponds to the
- * current value of the source folder field.
- *
- * @return the IPackageFragmentRoot or <code>null</code> if the current
- * source folder value is not a valid package fragment root
- *
- */
- public IPackageFragmentRoot getPackageFragmentRoot() {
- return fCurrRoot;
- }
-
- /**
- * Returns the current text of source folder text field.
- *
- * @return the text of the source folder text field
- */
- public String getPackageFragmentRootText() {
- return fContainerDialogField.getText();
- }
-
- /**
- * Sets the current source folder (model and text field) to the given
- * package fragment root.
- *
- * @param canBeModified
- * if <code>false</code> the source folder field can not be
- * changed by the user. If <code>true</code> the field is
- * editable
- */
- // public void setPackageFragmentRoot(IPackageFragmentRoot root, boolean
- // canBeModified) {
- // fCurrRoot= root;
- // String str= (root == null) ? "" :
- // root.getPath().makeRelative().toString(); //$NON-NLS-1$
- // fContainerDialogField.setText(str);
- // fContainerDialogField.setEnabled(canBeModified);
- // }
- // ------------- choose source container dialog
- // private IPackageFragmentRoot chooseSourceContainer(IJavaElement
- // initElement) {
- // Class[] acceptedClasses= new Class[] { IPackageFragmentRoot.class,
- // IJavaProject.class };
- // TypedElementSelectionValidator validator= new
- // TypedElementSelectionValidator(acceptedClasses, false) {
- // public boolean isSelectedValid(Object element) {
- // try {
- // if (element instanceof IJavaProject) {
- // IJavaProject jproject= (IJavaProject)element;
- // IPath path= jproject.getProject().getFullPath();
- // return (jproject.findPackageFragmentRoot(path) != null);
- // } else if (element instanceof IPackageFragmentRoot) {
- // return (((IPackageFragmentRoot)element).getKind() ==
- // IPackageFragmentRoot.K_SOURCE);
- // }
- // return true;
- // } catch (JavaModelException e) {
- // PHPeclipsePlugin.log(e.getStatus()); // just log, no ui in validation
- // }
- // return false;
- // }
- // };
- //
- // acceptedClasses= new Class[] { IJavaModel.class,
- // IPackageFragmentRoot.class, IJavaProject.class };
- // ViewerFilter filter= new TypedViewerFilter(acceptedClasses) {
- // public boolean select(Viewer viewer, Object parent, Object element) {
- // if (element instanceof IPackageFragmentRoot) {
- // try {
- // return (((IPackageFragmentRoot)element).getKind() ==
- // IPackageFragmentRoot.K_SOURCE);
- // } catch (JavaModelException e) {
- // PHPeclipsePlugin.log(e.getStatus()); // just log, no ui in validation
- // return false;
- // }
- // }
- // return super.select(viewer, parent, element);
- // }
- // };
- //
- // StandardJavaElementContentProvider provider= new
- // StandardJavaElementContentProvider();
- // ILabelProvider labelProvider= new
- // JavaElementLabelProvider(JavaElementLabelProvider.SHOW_DEFAULT);
- // ElementTreeSelectionDialog dialog= new
- // ElementTreeSelectionDialog(getShell(), labelProvider, provider);
- // dialog.setValidator(validator);
- // dialog.setSorter(new JavaElementSorter());
- // dialog.setTitle(NewWizardMessages.getString("NewContainerWizardPage.ChooseSourceContainerDialog.title"));
- // //$NON-NLS-1$
- // dialog.setMessage(NewWizardMessages.getString("NewContainerWizardPage.ChooseSourceContainerDialog.description"));
- // //$NON-NLS-1$
- // dialog.addFilter(filter);
- // dialog.setInput(JavaCore.create(fWorkspaceRoot));
- // dialog.setInitialSelection(initElement);
- //
- // if (dialog.open() == ElementTreeSelectionDialog.OK) {
- // Object element= dialog.getFirstResult();
- // if (element instanceof IJavaProject) {
- // IJavaProject jproject= (IJavaProject)element;
- // return jproject.getPackageFragmentRoot(jproject.getProject());
- // } else if (element instanceof IPackageFragmentRoot) {
- // return (IPackageFragmentRoot)element;
- // }
- // return null;
- // }
- // return null;
- // }
-}