/******************************************************************************* * 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.debug.ui.refactoring; import java.util.ArrayList; import java.util.List; import org.eclipse.core.resources.IMarker; import org.eclipse.core.resources.IResource; import org.eclipse.core.resources.ResourcesPlugin; import org.eclipse.core.runtime.CoreException; import org.eclipse.core.runtime.IPath; import org.eclipse.core.runtime.IProgressMonitor; import org.eclipse.core.runtime.OperationCanceledException; import org.eclipse.debug.core.DebugPlugin; import org.eclipse.debug.core.model.IBreakpoint; 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; import org.eclipse.php.internal.debug.core.model.PHPLineBreakpoint; /** * Breakpoint participant for a rename refactoring. * * @since 3.2 */ public abstract class BreakpointRenameParticipant extends RenameParticipant { /** * Element being renamed */ private IModelElement fElement; /* * (non-Javadoc) * * @see * org.eclipse.ltk.core.refactoring.participants.RefactoringParticipant# * initialize(java.lang.Object) */ 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() */ public String getName() { return RefactoringMessages.BreakpointRenameParticipant_0; } /* * (non-Javadoc) * * @see * org.eclipse.ltk.core.refactoring.participants.RefactoringParticipant# * checkConditions(org.eclipse.core.runtime.IProgressMonitor, * org.eclipse.ltk.core.refactoring.participants.CheckConditionsContext) */ 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) */ public Change createChange(IProgressMonitor pm) throws CoreException, OperationCanceledException { List changes = new ArrayList(); IResource resource = getBreakpointContainer(); IMarker[] markers = resource.findMarkers(IBreakpoint.BREAKPOINT_MARKER, true, IResource.DEPTH_INFINITE); gatherChanges(markers, changes, getArguments().getNewName()); if (changes.size() > 1) { return new CompositeChange(RefactoringMessages.BreakpointRenameParticipant_1, (Change[]) changes.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 void gatherChanges(IMarker[] markers, List changes, String destPackageName) throws CoreException, OperationCanceledException { for (int i = 0; i < markers.length; i++) { IMarker marker = markers[i]; IBreakpoint breakpoint = getBreakpoint(marker); if (breakpoint instanceof PHPLineBreakpoint) { PHPLineBreakpoint javaBreakpoint = (PHPLineBreakpoint) breakpoint; changes.add(createTypeChange(javaBreakpoint, marker.getResource(), getDestResource(marker.getResource(), destPackageName))); } } } protected IResource getDestResource(IResource resource, String destName) { IResource oldRes = fElement.getResource(); IResource newRes = null; if (oldRes != null) { IPath renamedPath = oldRes.getFullPath(); renamedPath = renamedPath.removeLastSegments(1).append(destName) .append(resource.getFullPath().removeFirstSegments(renamedPath.segmentCount())); newRes = ResourcesPlugin.getWorkspace().getRoot().getFile(renamedPath); } return newRes; } /** * 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(); } /** * Returns the breakpoint associated with the given marker. * * @param marker * breakpoint marker * @return breakpoint or <code>null</code> */ protected IBreakpoint getBreakpoint(IMarker marker) { return DebugPlugin.getDefault().getBreakpointManager().getBreakpoint(marker); } /** * Creates a specific type of change for a breakpoint that is changing * types. * * @return type change or <code>null</code> */ protected Change createTypeChange(PHPLineBreakpoint breakpoint, IResource originalType, IResource destType) throws CoreException { return new LineBreakpointTypeChange(breakpoint, originalType, destType); } /** * 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; } }