/******************************************************************************* * Copyright (c) 2005, 2006 IBM Corporation 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: * IBM Corporation - initial API and implementation *******************************************************************************/ package org.eclipse.php.internal.ui.refactor.participants; import java.util.ArrayList; import java.util.List; import org.eclipse.core.resources.IResource; import org.eclipse.core.runtime.CoreException; import org.eclipse.core.runtime.IProgressMonitor; import org.eclipse.core.runtime.OperationCanceledException; import org.eclipse.dltk.core.IModelElement; import org.eclipse.dltk.core.IType; import org.eclipse.ltk.core.refactoring.Change; import org.eclipse.ltk.core.refactoring.CompositeChange; import org.eclipse.ltk.core.refactoring.RefactoringStatus; import org.eclipse.ltk.core.refactoring.participants.CheckConditionsContext; import org.eclipse.ltk.core.refactoring.participants.RenameParticipant; /** * Breakpoint participant for a rename refactoring. * * @since 3.2 */ public abstract class IncludepathRenameParticipant extends RenameParticipant { /** * Element being renamed */ private IModelElement fElement; /* * (non-Javadoc) * * @see * org.eclipse.ltk.core.refactoring.participants.RefactoringParticipant# * initialize(java.lang.Object) */ @Override protected boolean initialize(Object element) { if (element instanceof IModelElement && accepts((IModelElement) element)) { fElement = (IModelElement) element; } else { return false; } return true; } /** * Returns the element this refactoring is operating on. * * @return */ protected IModelElement getOriginalElement() { return fElement; } /** * Returns whether this given element is a valid target for this operation. * * @param element * @return */ protected abstract boolean accepts(IModelElement element); /* * (non-Javadoc) * * @see * org.eclipse.ltk.core.refactoring.participants.RefactoringParticipant# * getName() */ @Override public String getName() { return ""; //$NON-NLS-1$ } /* * (non-Javadoc) * * @see * org.eclipse.ltk.core.refactoring.participants.RefactoringParticipant# * checkConditions(org.eclipse.core.runtime.IProgressMonitor, * org.eclipse.ltk.core.refactoring.participants.CheckConditionsContext) */ @Override public RefactoringStatus checkConditions(IProgressMonitor pm, CheckConditionsContext context) throws OperationCanceledException { return new RefactoringStatus(); } /* * (non-Javadoc) * * @see * org.eclipse.ltk.core.refactoring.participants.RefactoringParticipant# * createChange(org.eclipse.core.runtime.IProgressMonitor) */ @Override public Change createChange(IProgressMonitor pm) throws CoreException, OperationCanceledException { List changes = new ArrayList(); IResource resource = getBreakpointContainer(); gatherChanges(resource, changes, getArguments().getNewName()); if (changes.size() > 1) { return new CompositeChange("", (Change[]) changes //$NON-NLS-1$ .toArray(new Change[changes.size()])); } else if (changes.size() == 1) { return (Change) changes.get(0); } return null; } /** * Gathers refactoring specific changes. Subclasses must override. * * @param breakpoint * markers to consider during the change * @param list * to add changes to * @param name * of the element being renamed * @return changes for this refactoring. * @throws CoreException * @throws OperationCanceledException */ protected abstract void gatherChanges(IResource resource, List changes, String destName) throws CoreException, OperationCanceledException; /** * Returns the resource that should be considered when searching for * affected breakpoints. * * @return resource to search for breakpoint markers. */ protected IResource getBreakpointContainer() { return fElement.getResource(); } /** * Creates a specific type of change for a breakpoint that is changing * types. * * @return type change or <code>null</code> */ /** * Returns whether the given target type is contained in the specified * container type. * * @param container * @param target * @return */ protected boolean isContained(IModelElement container, IType type) { IModelElement parent = type; while (parent != null) { if (parent.equals(container)) { return true; } parent = parent.getParent(); } return false; } }