OSDN Git Service

C++ function link: Disable link if target editor changes.
authorChristian Kamm <christian.d.kamm@nokia.com>
Wed, 17 Aug 2011 10:21:04 +0000 (12:21 +0200)
committerChristian Kamm <christian.d.kamm@nokia.com>
Thu, 18 Aug 2011 08:57:40 +0000 (10:57 +0200)
Change-Id: I7041f3c520e88b4376c5cbac08ed79aa44641f0f
Reviewed-on: http://codereview.qt.nokia.com/3088
Reviewed-by: Leandro T. C. Melo <leandro.melo@nokia.com>
src/plugins/cppeditor/cppeditor.cpp
src/plugins/cppeditor/cppeditor.h
src/plugins/texteditor/refactoringchanges.h

index c15f1e0..8998fa3 100644 (file)
@@ -2302,6 +2302,14 @@ void CPPEditorWidget::onFunctionDeclDefLinkFound(QSharedPointer<FunctionDeclDefL
 {
     abortDeclDefLink();
     m_declDefLink = link;
+
+    // disable the link if content of the target editor changes
+    TextEditor::BaseTextEditorWidget *targetEditor =
+            TextEditor::RefactoringChanges::editorForFile(link->targetFile->fileName());
+    if (targetEditor) {
+        connect(targetEditor, SIGNAL(textChanged()),
+                this, SLOT(abortDeclDefLink()));
+    }
 }
 
 void CPPEditorWidget::applyDeclDefLinkChanges(bool jumpToMatch)
@@ -2317,6 +2325,15 @@ void CPPEditorWidget::abortDeclDefLink()
 {
     if (!m_declDefLink)
         return;
+
+    // undo connect from onFunctionDeclDefLinkFound
+    TextEditor::BaseTextEditorWidget *targetEditor =
+            TextEditor::RefactoringChanges::editorForFile(m_declDefLink->targetFile->fileName());
+    if (targetEditor) {
+        disconnect(targetEditor, SIGNAL(textChanged()),
+                   this, SLOT(abortDeclDefLink()));
+    }
+
     m_declDefLink->hideMarker(this);
     m_declDefLink.clear();
 }
index d07e53d..55278ba 100644 (file)
@@ -269,7 +269,7 @@ private:
     void abortRename();
 
     void applyDeclDefLinkChanges(bool jumpToMatch);
-    void abortDeclDefLink();
+    Q_SLOT void abortDeclDefLink();
 
     Link attemptFuncDeclDef(const QTextCursor &cursor,
                             const CPlusPlus::Document::Ptr &doc,
index 6dae8c5..4b2bc19 100644 (file)
@@ -120,11 +120,10 @@ public:
      */
     void activateEditor(const QString &fileName, int line, int column);
 
-
-private:
     static BaseTextEditorWidget *editorForFile(const QString &fileName,
                                          bool openIfClosed = false);
 
+private:
     static QList<QTextCursor> rangesToSelections(QTextDocument *document, const QList<Range> &ranges);
     virtual void indentSelection(const QTextCursor &selection,
                                  const QString &fileName,