blob: 74fc9ca30e9aa6062f1fac50515f848361a2c05b [file] [log] [blame]
/*******************************************************************************
* Copyright (c) 2000, 2017 IBM Corporation and others.
* This program and the accompanying materials are made available under the
* terms of the Eclipse Public License v. 2.0 which is available at
* http://www.eclipse.org/legal/epl-2.0.
*
* SPDX-License-Identifier: EPL-2.0
*
*******************************************************************************/
package org.eclipse.dltk.internal.ui.refactoring.reorg;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.HashSet;
import java.util.List;
import java.util.Set;
import org.eclipse.core.resources.IResource;
import org.eclipse.core.runtime.Assert;
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.ModelException;
import org.eclipse.dltk.internal.corext.refactoring.RefactoringCoreMessages;
import org.eclipse.dltk.internal.corext.refactoring.changes.DynamicValidationStateChange;
import org.eclipse.dltk.internal.corext.refactoring.participants.ResourceProcessors;
import org.eclipse.dltk.internal.corext.refactoring.participants.ScriptProcessors;
import org.eclipse.dltk.internal.corext.refactoring.reorg.ICreateTargetQueries;
import org.eclipse.dltk.internal.corext.refactoring.reorg.ICreateTargetQuery;
import org.eclipse.dltk.internal.corext.refactoring.reorg.IReorgDestinationValidator;
import org.eclipse.dltk.internal.corext.refactoring.reorg.IReorgPolicy.IMovePolicy;
import org.eclipse.dltk.internal.corext.refactoring.reorg.IReorgQueries;
import org.eclipse.dltk.internal.corext.refactoring.reorg.ParentChecker;
import org.eclipse.dltk.internal.corext.refactoring.reorg.ReorgUtils;
import org.eclipse.dltk.internal.corext.refactoring.tagging.ICommentProvider;
import org.eclipse.dltk.internal.corext.refactoring.tagging.IQualifiedNameUpdating;
import org.eclipse.dltk.internal.corext.refactoring.tagging.IScriptableRefactoring;
import org.eclipse.dltk.internal.corext.util.Resources;
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.TextEditBasedChange;
import org.eclipse.ltk.core.refactoring.participants.CheckConditionsContext;
import org.eclipse.ltk.core.refactoring.participants.MoveProcessor;
import org.eclipse.ltk.core.refactoring.participants.RefactoringArguments;
import org.eclipse.ltk.core.refactoring.participants.RefactoringParticipant;
import org.eclipse.ltk.core.refactoring.participants.SharableParticipants;
public final class ScriptMoveProcessor extends MoveProcessor
implements IScriptableRefactoring, ICommentProvider,
IQualifiedNameUpdating, IReorgDestinationValidator {
// TODO: offer IMovePolicy getMovePolicy(); IReorgPolicy getReorgPolicy();
// and remove delegate methods (also for CopyRefactoring)?
private IReorgQueries fReorgQueries;
private IMovePolicy fMovePolicy;
private ICreateTargetQueries fCreateTargetQueries;
private boolean fWasCanceled;
private String fComment;
public static final String IDENTIFIER = "org.eclipse.dltk.ui.MoveProcessor"; //$NON-NLS-1$
public ScriptMoveProcessor(IMovePolicy policy) {
fMovePolicy = policy;
}
protected Object getDestination() {
IModelElement je = fMovePolicy.getScriptElementDestination();
if (je != null)
return je;
return fMovePolicy.getResourceDestination();
}
@Override
public Object[] getElements() {
List result = new ArrayList();
result.addAll(Arrays.asList(fMovePolicy.getScriptElements()));
result.addAll(Arrays.asList(fMovePolicy.getResources()));
return result.toArray();
}
@Override
public String getIdentifier() {
return IDENTIFIER;
}
@Override
public boolean isApplicable() throws CoreException {
return fMovePolicy.canEnable();
}
@Override
public RefactoringParticipant[] loadParticipants(RefactoringStatus status,
SharableParticipants shared) throws CoreException {
return fMovePolicy.loadParticipants(status, this,
getAffectedProjectNatures(), shared);
}
private String[] getAffectedProjectNatures() throws CoreException {
String[] jNatures = ScriptProcessors
.computeAffectedNaturs(fMovePolicy.getScriptElements());
String[] rNatures = ResourceProcessors
.computeAffectedNatures(fMovePolicy.getResources());
Set<String> result = new HashSet<>();
result.addAll(Arrays.asList(jNatures));
result.addAll(Arrays.asList(rNatures));
return result.toArray(new String[result.size()]);
}
public boolean wasCanceled() {
return fWasCanceled;
}
@Override
public RefactoringStatus checkInitialConditions(IProgressMonitor pm)
throws CoreException {
pm.beginTask("", 1); //$NON-NLS-1$
try {
RefactoringStatus result = new RefactoringStatus();
result.merge(RefactoringStatus.create(Resources.checkInSync(
ReorgUtils.getNotNulls(fMovePolicy.getResources()))));
IResource[] javaResources = ReorgUtils
.getResources(fMovePolicy.getScriptElements());
result.merge(RefactoringStatus.create(Resources
.checkInSync(ReorgUtils.getNotNulls(javaResources))));
return result;
} finally {
pm.done();
}
}
public Object getCommonParentForInputElements() {
return new ParentChecker(fMovePolicy.getResources(),
fMovePolicy.getScriptElements()).getCommonParent();
}
public IModelElement[] getScriptElements() {
return fMovePolicy.getScriptElements();
}
public IResource[] getResources() {
return fMovePolicy.getResources();
}
public RefactoringStatus setDestination(IModelElement destination)
throws ModelException {
return fMovePolicy.setDestination(destination);
}
public RefactoringStatus setDestination(IResource destination)
throws ModelException {
return fMovePolicy.setDestination(destination);
}
@Override
public boolean canChildrenBeDestinations(IModelElement modelElement) {
return fMovePolicy.canChildrenBeDestinations(modelElement);
}
@Override
public boolean canChildrenBeDestinations(IResource resource) {
return fMovePolicy.canChildrenBeDestinations(resource);
}
@Override
public boolean canElementBeDestination(IModelElement modelElement) {
return fMovePolicy.canElementBeDestination(modelElement);
}
@Override
public boolean canElementBeDestination(IResource resource) {
return fMovePolicy.canElementBeDestination(resource);
}
public void setReorgQueries(IReorgQueries queries) {
Assert.isNotNull(queries);
fReorgQueries = queries;
}
@Override
public RefactoringStatus checkFinalConditions(IProgressMonitor pm,
CheckConditionsContext context) throws CoreException {
try {
Assert.isNotNull(fReorgQueries);
fWasCanceled = false;
return fMovePolicy.checkFinalConditions(pm, context, fReorgQueries);
} catch (OperationCanceledException e) {
fWasCanceled = true;
throw e;
}
}
@Override
public Change createChange(IProgressMonitor pm) throws CoreException {
Assert.isTrue(fMovePolicy.getScriptElementDestination() == null
|| fMovePolicy.getResourceDestination() == null);
Assert.isTrue(fMovePolicy.getScriptElementDestination() != null
|| fMovePolicy.getResourceDestination() != null);
try {
final DynamicValidationStateChange result = new DynamicValidationStateChange(
RefactoringCoreMessages.ScriptMoveProcessor_change_name) {
@Override
public Change perform(IProgressMonitor pm2)
throws CoreException {
Change change = super.perform(pm2);
Change[] changes = getChildren();
for (int index = 0; index < changes.length; index++) {
if (!(changes[index] instanceof TextEditBasedChange))
return null;
}
return change;
}
};
Change change = fMovePolicy.createChange(pm);
if (change instanceof CompositeChange) {
CompositeChange subComposite = (CompositeChange) change;
result.merge(subComposite);
} else {
result.add(change);
}
return result;
} finally {
pm.done();
}
}
@Override
public Change postCreateChange(Change[] participantChanges,
IProgressMonitor pm) throws CoreException {
return fMovePolicy.postCreateChange(participantChanges, pm);
}
@Override
public String getProcessorName() {
return RefactoringCoreMessages.MoveRefactoring_0;
}
public boolean canUpdateReferences() {
return fMovePolicy.canUpdateReferences();
}
public void setUpdateReferences(boolean update) {
fMovePolicy.setUpdateReferences(update);
}
public boolean getUpdateReferences() {
if (!canUpdateReferences())
return false;
return fMovePolicy.getUpdateReferences();
}
@Override
public boolean canEnableQualifiedNameUpdating() {
return fMovePolicy.canEnableQualifiedNameUpdating();
}
public boolean canUpdateQualifiedNames() {
return fMovePolicy.canUpdateQualifiedNames();
}
@Override
public String getFilePatterns() {
return fMovePolicy.getFilePatterns();
}
@Override
public boolean getUpdateQualifiedNames() {
return fMovePolicy.getUpdateQualifiedNames();
}
@Override
public void setFilePatterns(String patterns) {
fMovePolicy.setFilePatterns(patterns);
}
@Override
public void setUpdateQualifiedNames(boolean update) {
fMovePolicy.setUpdateQualifiedNames(update);
}
public boolean hasAllInputSet() {
return fMovePolicy.hasAllInputSet();
}
public boolean hasDestinationSet() {
return fMovePolicy.getScriptElementDestination() != null
|| fMovePolicy.getResourceDestination() != null;
}
public void setCreateTargetQueries(ICreateTargetQueries queries) {
Assert.isNotNull(queries);
fCreateTargetQueries = queries;
}
/**
* @return the create target queries, or <code>null</code> if creating new
* targets is not supported
*/
public ICreateTargetQuery getCreateTargetQuery() {
return fMovePolicy.getCreateTargetQuery(fCreateTargetQueries);
}
public boolean isTextualMove() {
return fMovePolicy.isTextualMove();
}
@Override
public RefactoringStatus initialize(RefactoringArguments arguments) {
// TODO Auto-generated method stub
return null;
}
@Override
public boolean canEnableComment() {
return true;
}
@Override
public String getComment() {
return fComment;
}
@Override
public void setComment(String comment) {
fComment = comment;
}
}