OSDN Git Service

QmlJS semantic highlighter: Abort when file changes.
authorChristian Kamm <christian.d.kamm@nokia.com>
Mon, 12 Sep 2011 10:58:59 +0000 (12:58 +0200)
committerChristian Kamm <christian.d.kamm@nokia.com>
Mon, 12 Sep 2011 11:30:09 +0000 (13:30 +0200)
Fixes the warning in incrementalApplyExtraAdditionalFormats being
triggered when the document is reduced in size while a highlight is
running.

Change-Id: I60e0c8772d511f52ee433d27cc77ba726030b354
Reviewed-on: http://codereview.qt-project.org/4661
Reviewed-by: Leandro T. C. Melo <leandro.melo@nokia.com>
src/plugins/qmljseditor/qmljseditor.cpp
src/plugins/qmljseditor/qmljssemantichighlighter.cpp
src/plugins/qmljseditor/qmljssemantichighlighter.h

index b39eec3..5ec720f 100644 (file)
@@ -1015,6 +1015,8 @@ void QmlJSTextEditorWidget::showTextMarker()
 
 void QmlJSTextEditorWidget::updateUses()
 {
+    if (m_semanticHighlighter->startRevision() != editorRevision())
+        m_semanticHighlighter->cancel();
     m_updateUsesTimer->start();
 }
 
index c45fe9d..dab142f 100644 (file)
@@ -386,6 +386,11 @@ void SemanticHighlighter::rerun(const ScopeChain &scopeChain)
     m_watcher.setFuture(f);
 }
 
+void SemanticHighlighter::cancel()
+{
+    m_watcher.cancel();
+}
+
 void SemanticHighlighter::applyResults(int from, int to)
 {
     if (m_watcher.isCanceled())
@@ -432,3 +437,7 @@ void SemanticHighlighter::updateFontSettings(const TextEditor::FontSettings &fon
     m_formats[LocalStateNameType] = fontSettings.toTextCharFormat(QLatin1String(TextEditor::Constants::C_QML_STATE_NAME));
 }
 
+int SemanticHighlighter::startRevision() const
+{
+    return m_startRevision;
+}
index be5d7a1..18ee030 100644 (file)
@@ -77,6 +77,9 @@ public:
     SemanticHighlighter(QmlJSTextEditorWidget *editor);
 
     void rerun(const QmlJS::ScopeChain &scopeChain);
+    void cancel();
+
+    int startRevision() const;
 
     void updateFontSettings(const TextEditor::FontSettings &fontSettings);