TextEditor: Fix wrong tooltip when split mode is used

It was possible to get a tooltip with cached text from other editor area

Fixes: QTCREATORBUG-28571
Change-Id: I4250856e6c165eed70ddb4a6c888e16b4a6b045d
Reviewed-by: <github-actions-qt-creator@cristianadam.eu>
Reviewed-by: David Schulz <david.schulz@qt.io>
This commit is contained in:
Mikhail Khachayants
2022-12-06 15:28:39 +03:00
parent 763c76b477
commit 81075b813c
3 changed files with 15 additions and 3 deletions

View File

@@ -19,6 +19,11 @@ void BaseHoverHandler::showToolTip(TextEditorWidget *widget, const QPoint &point
operateTooltip(widget, point); operateTooltip(widget, point);
} }
bool BaseHoverHandler::lastHelpItemAppliesTo(const TextEditorWidget *widget) const
{
return m_lastWidget == widget;
}
void BaseHoverHandler::checkPriority(TextEditorWidget *widget, void BaseHoverHandler::checkPriority(TextEditorWidget *widget,
int pos, int pos,
ReportPriority report) ReportPriority report)
@@ -106,8 +111,12 @@ void BaseHoverHandler::process(TextEditorWidget *widget, int pos, ReportPriority
m_toolTip.clear(); m_toolTip.clear();
m_priority = -1; m_priority = -1;
m_lastHelpItemIdentified = Core::HelpItem(); m_lastHelpItemIdentified = Core::HelpItem();
m_lastWidget = nullptr;
identifyMatch(widget, pos, report); identifyMatch(widget, pos, [this, widget, report](int priority) {
m_lastWidget = widget;
report(priority);
});
} }
void BaseHoverHandler::identifyMatch(TextEditorWidget *editorWidget, int pos, ReportPriority report) void BaseHoverHandler::identifyMatch(TextEditorWidget *editorWidget, int pos, ReportPriority report)

View File

@@ -32,6 +32,7 @@ public:
virtual void abort() {} // Implement for asynchronous priority reporter virtual void abort() {} // Implement for asynchronous priority reporter
void showToolTip(TextEditorWidget *widget, const QPoint &point); void showToolTip(TextEditorWidget *widget, const QPoint &point);
bool lastHelpItemAppliesTo(const TextEditorWidget *widget) const;
protected: protected:
enum { enum {
@@ -68,6 +69,7 @@ private:
Core::HelpItem m_lastHelpItemIdentified; Core::HelpItem m_lastHelpItemIdentified;
int m_priority = -1; int m_priority = -1;
bool m_isContextHelpRequest = false; bool m_isContextHelpRequest = false;
TextEditorWidget *m_lastWidget = nullptr;
}; };
} // namespace TextEditor } // namespace TextEditor

View File

@@ -294,7 +294,7 @@ public:
// Does the last handler still applies? // Does the last handler still applies?
const int documentRevision = textCursor.document()->revision(); const int documentRevision = textCursor.document()->revision();
const int position = Text::wordStartCursor(textCursor).position(); const int position = Text::wordStartCursor(textCursor).position();
if (m_lastHandlerInfo.applies(documentRevision, position)) { if (m_lastHandlerInfo.applies(documentRevision, position, m_widget)) {
callback(m_widget, m_lastHandlerInfo.handler, position); callback(m_widget, m_lastHandlerInfo.handler, position);
return; return;
} }
@@ -399,9 +399,10 @@ private:
, cursorPosition(cursorPosition) , cursorPosition(cursorPosition)
{} {}
bool applies(int documentRevision, int cursorPosition) const bool applies(int documentRevision, int cursorPosition, TextEditorWidget *widget) const
{ {
return handler return handler
&& handler->lastHelpItemAppliesTo(widget)
&& documentRevision == this->documentRevision && documentRevision == this->documentRevision
&& cursorPosition == this->cursorPosition; && cursorPosition == this->cursorPosition;
} }