use of org.eclipse.ltk.core.refactoring.TextFileChange in project che by eclipse.
the class RefactoringCorrectionProposal method createTextChange.
@Override
protected TextChange createTextChange() throws CoreException {
init(fRefactoring);
fRefactoringStatus = fRefactoring.checkFinalConditions(new NullProgressMonitor());
if (fRefactoringStatus.hasFatalError()) {
//$NON-NLS-1$
TextFileChange dummyChange = new TextFileChange("fatal error", (IFile) getCompilationUnit().getResource());
//$NON-NLS-1$
dummyChange.setEdit(new InsertEdit(0, ""));
return dummyChange;
}
return (TextChange) fRefactoring.createChange(new NullProgressMonitor());
}
use of org.eclipse.ltk.core.refactoring.TextFileChange in project che by eclipse.
the class QualifiedNameSearchResult method getSingleChange.
public Change getSingleChange(IFile[] alreadyTouchedFiles) {
Collection<TextChange> values = fChanges.values();
if (values.size() == 0)
return null;
CompositeChange result = new CompositeChange(RefactoringCoreMessages.QualifiedNameSearchResult_change_name);
result.markAsSynthetic();
List<IFile> files = Arrays.asList(alreadyTouchedFiles);
for (Iterator<TextChange> iter = values.iterator(); iter.hasNext(); ) {
TextFileChange change = (TextFileChange) iter.next();
if (!files.contains(change.getFile())) {
result.add(change);
}
}
return result;
}
use of org.eclipse.ltk.core.refactoring.TextFileChange in project ch.hsr.ifs.cdttesting by IFS-HSR.
the class MyQuickFix method modifyAST.
@Override
public void modifyAST(IIndex index, IMarker marker) {
try {
@SuppressWarnings("unused") IASTTranslationUnit ast = getTranslationUnitViaEditor(marker).getAST(index, ITranslationUnit.AST_SKIP_INDEXED_HEADERS);
// a real test should use ModificationCollector/ASTRewrite or Refactoring here.
// For testing purposes, we only replace some text directly.
TextFileChange change = new TextFileChange("rename foo to bar text edit", (IFile) marker.getResource());
change.setEdit(new ReplaceEdit(4, 3, "bar"));
change.perform(new NullProgressMonitor());
} catch (CoreException e) {
throw new RuntimeException(e);
}
}
use of org.eclipse.ltk.core.refactoring.TextFileChange in project xtext-eclipse by eclipse.
the class TextChangeCombinerTest method testSingleFileChange.
@Test
public void testSingleFileChange() throws Exception {
Change textFileChange = createTextFileChange(file0, 1, 1, "foo");
Change combined = combiner.combineChanges(textFileChange);
assertTextType(combined);
assertEquals(textFileChange, combined);
Change undo = combined.perform(new NullProgressMonitor());
assertEquals(MODEL.replace("1", "foo"), getContents(file0));
undo.perform(new NullProgressMonitor());
assertEquals(MODEL, getContents(file0));
}
use of org.eclipse.ltk.core.refactoring.TextFileChange in project bndtools by bndtools.
the class PkgRenameParticipant method createChange.
@Override
public Change createChange(IProgressMonitor pm) throws CoreException, OperationCanceledException {
final Map<IFile, TextChange> fileChanges = new HashMap<IFile, TextChange>();
IResourceProxyVisitor visitor = new IResourceProxyVisitor() {
@Override
public boolean visit(IResourceProxy proxy) throws CoreException {
if ((proxy.getType() == IResource.FOLDER) || (proxy.getType() == IResource.PROJECT)) {
return true;
}
if (!((proxy.getType() == IResource.FILE) && proxy.getName().toLowerCase().endsWith(".bnd"))) {
return false;
}
/* we're dealing with a *.bnd file */
/* get the proxied file */
IFile resource = (IFile) proxy.requestResource();
/* read the file as a single string */
String bndFileText = null;
try {
bndFileText = FileUtils.readFully(resource).get();
} catch (Exception e) {
String str = "Could not read file " + proxy.getName();
logger.logError(str, e);
throw new OperationCanceledException(str);
}
/*
* get the previous change for this file if it exists, or otherwise create a new change for it, but do
* not store it yet: wait until we know if there are actually changes in the file
*/
TextChange fileChange = getTextChange(resource);
final boolean fileChangeIsNew = (fileChange == null);
if (fileChange == null) {
fileChange = new TextFileChange(proxy.getName(), resource);
fileChange.setEdit(new MultiTextEdit());
}
TextEdit rootEdit = fileChange.getEdit();
BndEditModel model = new BndEditModel();
Document document = new Document(bndFileText);
try {
model.loadFrom(document);
} catch (IOException e) {
String str = "Could not load document " + proxy.getName();
logger.logError(str, e);
throw new OperationCanceledException(str);
}
/* loop over all renames to perform */
for (Map.Entry<IPackageFragment, RenameArguments> entry : pkgFragments.entrySet()) {
IPackageFragment pkgFragment = entry.getKey();
RenameArguments arguments = entry.getValue();
final String oldName = pkgFragment.getElementName();
final String newName = arguments.getNewName();
List<ImportPattern> newImportedPackages = makeNewHeaders(model.getImportPatterns(), oldName, newName);
if (newImportedPackages != null) {
model.setImportPatterns(newImportedPackages);
}
List<ExportedPackage> newExportedPackages = makeNewHeaders(model.getExportedPackages(), oldName, newName);
if (newExportedPackages != null) {
model.setExportedPackages(newExportedPackages);
}
List<String> newPrivatePackages = makeNewHeaders(model.getPrivatePackages(), oldName, newName);
if (newPrivatePackages != null) {
model.setPrivatePackages(newPrivatePackages);
}
Map<String, String> changes = model.getDocumentChanges();
for (Iterator<Entry<String, String>> iter = changes.entrySet().iterator(); iter.hasNext(); ) {
Entry<String, String> change = iter.next();
String propertyName = change.getKey();
String stringValue = change.getValue();
addEdit(document, rootEdit, propertyName, stringValue);
iter.remove();
}
Pattern pattern = Pattern.compile(/* match start boundary */
"(^|" + grammarSeparator + ")" + /* match bundle activator */
"(Bundle-Activator\\s*:\\s*)" + /* match itself / package name */
"(" + Pattern.quote(oldName) + ")" + /* match class name */
"(\\.[^\\.]+)" + /* match end boundary */
"(" + grammarSeparator + "|" + Pattern.quote("\\") + "|$)");
/* find all matches to replace and add them to the root edit */
Matcher matcher = pattern.matcher(bndFileText);
while (matcher.find()) {
rootEdit.addChild(new ReplaceEdit(matcher.start(3), matcher.group(3).length(), newName));
}
}
/*
* only store the changes when no changes were stored before for this file and when there are actually
* changes.
*/
if (fileChangeIsNew && rootEdit.hasChildren()) {
fileChanges.put(resource, fileChange);
}
return false;
}
};
/* determine which projects have to be visited */
Set<IProject> projectsToVisit = new HashSet<IProject>();
for (IPackageFragment pkgFragment : pkgFragments.keySet()) {
projectsToVisit.add(pkgFragment.getResource().getProject());
for (IProject projectToVisit : pkgFragment.getResource().getProject().getReferencingProjects()) {
projectsToVisit.add(projectToVisit);
}
for (IProject projectToVisit : pkgFragment.getResource().getProject().getReferencedProjects()) {
projectsToVisit.add(projectToVisit);
}
}
/* visit the projects */
for (IProject projectToVisit : projectsToVisit) {
projectToVisit.accept(visitor, IResource.NONE);
}
if (fileChanges.isEmpty()) {
/* no changes at all */
return null;
}
/* build a composite change with all changes */
CompositeChange cs = new CompositeChange(changeTitle);
for (TextChange fileChange : fileChanges.values()) {
cs.add(fileChange);
}
return cs;
}
Aggregations