[drkonqi] [Bug 381644] Dr. Konqi Crashes During Crash Report
Harald Sitter
bugzilla_noreply at kde.org
Thu Jun 27 12:43:25 BST 2019
https://bugs.kde.org/show_bug.cgi?id=381644
Harald Sitter <sitter at kde.org> changed:
What |Removed |Added
----------------------------------------------------------------------------
Resolution|--- |FIXED
Status|REPORTED |RESOLVED
Version Fixed In| |5.16.1
Latest Commit| |https://commits.kde.org/drk
| |onqi/c2775e7335a13f2d2a4da6
| |7e2488aa8c71708cf8
--- Comment #26 from Harald Sitter <sitter at kde.org> ---
Git commit c2775e7335a13f2d2a4da67e2488aa8c71708cf8 by Harald Sitter.
Committed on 27/06/2019 at 11:38.
Pushed by sitter into branch 'Plasma/5.16'.
force the backtracewidget into loading state when the generator is loading
Summary:
this specifically unsets the m_highlighter which absolutely must not be
present when in loading state (or more specifically: when receiving lines
as-they-appear as opposed to the finished backtrace).
also assert that the widget has no highlighter when loading lines
the highlighter design is fairly wonky, it actually highlights off of the
qtextdocument, but to highlight it needs to know the actual parsed trace
Line entities and they are of course no longer present because the
document only has a text blob. to bridge that disconnect the highlighter
needs to match up the textual lines to the Line entities by their index.
naturally this is a potential bundle of segfault sources when the two
sources no longer align.
unfortunately that is exactly what could happen:
technically speaking drkonqi has two instances of backtracewidget. one
in the main dialog and one in the report dialog. they both use the same
generator though. so what happened was a confusion over which state the
widget needs to be in vis a vis the generator. if the first widget already
loaded a backtrace the generator would be in Loaded state and so would the
widget (i.e. it'd have a highlighter). if the user then proceeds to the
report dialog and they'd get a new widget with a reload button. if the user
then would use the reload button the new widget would be fine, it would
trigger a "reload". the old widget however would not know anything about
the reload and continue to be in Loaded state with a highlighter attached.
as the generator now sends lines to the old and the new widget, the old
widget would receive the lines with a highlighter attached.
bang! the (new) lines disalign with the Line entities in the highlighter
and all hell breaks loose.
this quite possibly fixes all occurrences of the #381644 crasher, but I
wouldn't exclude other points of frailty. as mentioned, the way the
highlighter's connecting textual lines to Line entities is fairly
fragile in of itself.
CHANGELOG: No longer crashes when reloading backtraces under certain
circumstances
FIXED-IN: 5.16.1
Test Plan:
- killall -SEGV dolphin
- open drkonqi
- go to backtrace tab
- let backtrace
- click report bug
- proceed to backtrace page
- click reload
- no crashy
Reviewers: #plasma
Subscribers: plasma-devel
Tags: #plasma
Differential Revision: https://phabricator.kde.org/D21801
M +6 -0 src/backtracewidget.cpp
https://commits.kde.org/drkonqi/c2775e7335a13f2d2a4da67e2488aa8c71708cf8
--
You are receiving this mail because:
You are the assignee for the bug.
More information about the Unassigned-bugs
mailing list