blob: 75d35c4cdcc2f43ff93b7cf09d56a2ee2366596e [file] [log] [blame]
/*******************************************************************************
* Copyright (c) 2000, 2005 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.jdt.internal.corext.refactoring.util;
import java.util.HashMap;
import java.util.Map;
import org.eclipse.jdt.core.ICompilationUnit;
import org.eclipse.jdt.internal.corext.refactoring.changes.CompilationUnitChange;
import org.eclipse.ltk.core.refactoring.TextChange;
/**
* A <code>TextChangeManager</code> manages associations between <code>ICompilationUnit</code>
* or <code>IFile</code> and <code>TextChange</code> objects.
*/
public class TextChangeManager {
private Map fMap= new HashMap(10); // ICompilationUnit -> TextChange
private final boolean fKeepExecutedTextEdits;
public TextChangeManager() {
this(false);
}
public TextChangeManager(boolean keepExecutedTextEdits) {
fKeepExecutedTextEdits= keepExecutedTextEdits;
}
/**
* Adds an association between the given compilation unit and the passed
* change to this manager.
*
* @param cu the compilation unit (key)
* @param change the change associated with the compilation unit
*/
public void manage(ICompilationUnit cu, TextChange change) {
fMap.put(cu, change);
}
/**
* Returns the <code>TextChange</code> associated with the given compilation unit.
* If the manager does not already manage an association it creates a one.
*
* @param cu the compilation unit for which the text buffer change is requested
* @return the text change associated with the given compilation unit.
*/
public TextChange get(ICompilationUnit cu) {
TextChange result= (TextChange)fMap.get(cu);
if (result == null) {
result= new CompilationUnitChange(cu.getElementName(), cu);
result.setKeepPreviewEdits(fKeepExecutedTextEdits);
fMap.put(cu, result);
}
return result;
}
/**
* Removes the <tt>TextChange</tt> managed under the given key
* <code>unit<code>.
*
* @param unit the key determining the <tt>TextChange</tt> to be removed.
* @return the removed <tt>TextChange</tt>.
*/
public TextChange remove(ICompilationUnit unit) {
return (TextChange)fMap.remove(unit);
}
/**
* Returns all text changes managed by this instance.
*
* @return all text changes managed by this instance
*/
public TextChange[] getAllChanges(){
return (TextChange[])fMap.values().toArray(new TextChange[fMap.values().size()]);
}
/**
* Returns all compilation units managed by this instance.
*
* @return all compilation units managed by this instance
*/
public ICompilationUnit[] getAllCompilationUnits(){
return (ICompilationUnit[]) fMap.keySet().toArray(new ICompilationUnit[fMap.keySet().size()]);
}
/**
* Clears all associations between resources and text changes.
*/
public void clear() {
fMap.clear();
}
/**
* Returns if any text changes are managed for the specified compilation unit.
*
* @param cu the compilation unit
* @return <code>true</code> if any text changes are managed for the specified compilation unit and <code>false</code> otherwise
*/
public boolean containsChangesIn(ICompilationUnit cu){
return fMap.containsKey(cu);
}
}