Use the existing text editor when refactoring text.

This commit is contained in:
Roberto Raggi
2009-10-06 14:22:42 +02:00
parent debe180872
commit fe1411cdfd

View File

@@ -36,6 +36,7 @@
#include <extensionsystem/pluginmanager.h> #include <extensionsystem/pluginmanager.h>
#include <utils/filesearch.h> #include <utils/filesearch.h>
#include <coreplugin/progressmanager/progressmanager.h> #include <coreplugin/progressmanager/progressmanager.h>
#include <coreplugin/editormanager/editormanager.h>
#include <coreplugin/icore.h> #include <coreplugin/icore.h>
#include <ASTVisitor.h> #include <ASTVisitor.h>
@@ -574,6 +575,23 @@ void CppFindReferences::findAll_helper(Symbol *symbol)
connect(progress, SIGNAL(clicked()), _resultWindow, SLOT(popup())); connect(progress, SIGNAL(clicked()), _resultWindow, SLOT(popup()));
} }
static void applyChanges(QTextDocument *doc, const QString &text, const QList<Find::SearchResultItem> &items)
{
QList<QTextCursor> cursors;
foreach (const Find::SearchResultItem &item, items) {
const int blockNumber = item.lineNumber - 1;
QTextCursor tc(doc->findBlockByNumber(blockNumber));
tc.setPosition(tc.position() + item.searchTermStart);
tc.setPosition(tc.position() + item.searchTermLength,
QTextCursor::KeepAnchor);
cursors.append(tc);
}
foreach (QTextCursor tc, cursors)
tc.insertText(text);
}
void CppFindReferences::onReplaceButtonClicked(const QString &text, void CppFindReferences::onReplaceButtonClicked(const QString &text,
const QList<Find::SearchResultItem> &items) const QList<Find::SearchResultItem> &items)
{ {
@@ -585,41 +603,48 @@ void CppFindReferences::onReplaceButtonClicked(const QString &text,
foreach (const Find::SearchResultItem &item, items) foreach (const Find::SearchResultItem &item, items)
changes[item.fileName].append(item); changes[item.fileName].append(item);
Core::EditorManager *editorManager = Core::EditorManager::instance();
QHashIterator<QString, QList<Find::SearchResultItem> > it(changes); QHashIterator<QString, QList<Find::SearchResultItem> > it(changes);
while (it.hasNext()) { while (it.hasNext()) {
it.next(); it.next();
const QString fileName = it.key(); const QString fileName = it.key();
QFile file(fileName); const QList<Find::SearchResultItem> items = it.value();
if (file.open(QFile::ReadOnly)) { const QList<Core::IEditor *> editors = editorManager->editorsForFileName(fileName);
QTextStream stream(&file); TextEditor::BaseTextEditor *textEditor = 0;
// ### set the encoding foreach (Core::IEditor *editor, editors) {
const QString plainText = stream.readAll(); textEditor = qobject_cast<TextEditor::BaseTextEditor *>(editor->widget());
file.close(); if (textEditor != 0)
break;
}
QTextDocument doc; if (textEditor != 0) {
doc.setPlainText(plainText); QTextCursor tc = textEditor->textCursor();
tc.beginEditBlock();
applyChanges(textEditor->document(), text, items);
tc.endEditBlock();
} else {
QFile file(fileName);
QList<QTextCursor> cursors; if (file.open(QFile::ReadOnly)) {
const QList<Find::SearchResultItem> items = it.value(); QTextStream stream(&file);
foreach (const Find::SearchResultItem &item, items) {
const int blockNumber = item.lineNumber - 1;
QTextCursor tc(doc.findBlockByNumber(blockNumber));
tc.setPosition(tc.position() + item.searchTermStart);
tc.setPosition(tc.position() + item.searchTermLength,
QTextCursor::KeepAnchor);
cursors.append(tc);
}
foreach (QTextCursor tc, cursors)
tc.insertText(text);
QFile newFile(fileName);
if (newFile.open(QFile::WriteOnly)) {
QTextStream stream(&newFile);
// ### set the encoding // ### set the encoding
stream << doc.toPlainText(); const QString plainText = stream.readAll();
file.close();
QTextDocument doc;
doc.setPlainText(plainText);
applyChanges(&doc, text, items);
QFile newFile(fileName);
if (newFile.open(QFile::WriteOnly)) {
QTextStream stream(&newFile);
// ### set the encoding
stream << doc.toPlainText();
}
} }
} }
} }