summaryrefslogtreecommitdiff
path: root/src/plugins/texteditor/refactoringchanges.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'src/plugins/texteditor/refactoringchanges.cpp')
-rw-r--r--src/plugins/texteditor/refactoringchanges.cpp16
1 files changed, 16 insertions, 0 deletions
diff --git a/src/plugins/texteditor/refactoringchanges.cpp b/src/plugins/texteditor/refactoringchanges.cpp
index a79b31d660..f5638ae600 100644
--- a/src/plugins/texteditor/refactoringchanges.cpp
+++ b/src/plugins/texteditor/refactoringchanges.cpp
@@ -30,13 +30,18 @@
#include "refactoringchanges.h"
#include "basetexteditor.h"
+#include <coreplugin/icore.h>
+#include <coreplugin/dialogs/readonlyfilesdialog.h>
#include <utils/qtcassert.h>
+#include <utils/fileutils.h>
#include <QFile>
+#include <QFileInfo>
#include <QTextBlock>
#include <QTextCursor>
#include <QTextDocument>
#include <QDebug>
+#include <QApplication>
using namespace TextEditor;
@@ -319,6 +324,17 @@ void RefactoringFile::setOpenEditor(bool activate, int pos)
void RefactoringFile::apply()
{
+ // test file permissions
+ if (!QFileInfo(fileName()).isWritable()) {
+ const QString &path = fileName();
+ Core::Internal::ReadOnlyFilesDialog roDialog(path, Core::ICore::mainWindow());
+ const QString &failDetailText = QApplication::translate("RefactoringFile::apply",
+ "Refactoring cannot be applied.");
+ roDialog.setShowFailWarning(true, failDetailText);
+ if (roDialog.exec() == Core::Internal::ReadOnlyFilesDialog::RO_Cancel)
+ return;
+ }
+
// open / activate / goto position
if (m_openEditor && !m_fileName.isEmpty()) {
unsigned line = unsigned(-1), column = unsigned(-1);