Summary: | Haskell intendation segmentation fault | ||
---|---|---|---|
Product: | [Applications] kate | Reporter: | womgli |
Component: | indentation | Assignee: | KWrite Developers <kwrite-bugs-null> |
Status: | RESOLVED FIXED | ||
Severity: | crash | CC: | christoph, jowenn, walch.martin, xrg |
Priority: | NOR | ||
Version: | 3.13.2 | ||
Target Milestone: | --- | ||
Platform: | Kubuntu | ||
OS: | Linux | ||
Latest Commit: | http://commits.kde.org/kate/c2a1c24f28613342985aa40573fb922370900a3a | Version Fixed In: | 4.14.1 |
Sentry Crash Report: | |||
Attachments: |
New crash information added by DrKonqi
proposal for a fix by adding one default KateHlContext |
Description
womgli
2014-07-25 02:12:37 UTC
Created attachment 87960 [details]
New crash information added by DrKonqi
kate (3.13.3) on KDE Platform 4.13.3 using Qt 4.8.5
I can confirm this crash.
This stacktrace should help getting more insight.
What is not visible in the stack: the invocation of document.isCode is in the haskell indenter haskell.js in line 337:
document.isCode(line - 1, document.lineLength(lastLine) - 1)
Taking a closer look soon.
-- Backtrace (Reduced):
#6 0x00007fa79eb682b3 in KateDocument::defStyleNum (this=0x1a23330, line=1, column=8) at /var/tmp/portage/kde-base/katepart-4.13.3/work/katepart-4.13.3/part/document/katedocument.cpp:5487
#7 0x00007fa79eb89492 in KateScriptDocument::defStyleNum (this=0x206a520, line=1, column=8) at /var/tmp/portage/kde-base/katepart-4.13.3/work/katepart-4.13.3/part/script/katescriptdocument.cpp:51
#8 0x00007fa79eb8950a in KateScriptDocument::isCode (this=0x206a520, line=1, column=8) at /var/tmp/portage/kde-base/katepart-4.13.3/work/katepart-4.13.3/part/script/katescriptdocument.cpp:62
#9 0x00007fa79ead7855 in KateScriptDocument::qt_static_metacall (_o=0x206a520, _c=QMetaObject::InvokeMetaMethod, _id=86, _a=0x7fff1f1c7150) at /var/tmp/portage/kde-base/katepart-4.13.3/work/katepart-4.13.3_build/part/moc_katescriptdocument.cpp:397
#10 0x00007fa79ead7f90 in KateScriptDocument::qt_metacall (this=0x206a520, _c=QMetaObject::InvokeMetaMethod, _id=86, _a=0x7fff1f1c7150) at /var/tmp/portage/kde-base/katepart-4.13.3/work/katepart-4.13.3_build/part/moc_katescriptdocument.cpp:467
In katedocument.cpp:5486, there is a bad call to highlight()->contextNum(0), when using no highlighting, as in that case the KateHighlighting object highlight() has no KateHlContext at all. I wonder whether a proper fix involves adding some "default" context to the "None" highlighter or not. Maybe I get to look into this tomorrow. Actually, even the "none" hl should have a default context: if (def == 0) { noHl = true; iName = QString::fromLatin1("None"); // not translated internal name (for config and more) iNameTranslated = i18nc("Syntax highlighting", "None"); // user visible name iSection = QString(); makeNoneContext(); } (In reply to Christoph Cullmann from comment #3) > Actually, even the "none" hl should have a default context: > > if (def == 0) { > noHl = true; > iName = QString::fromLatin1("None"); // not translated internal name > (for config and more) > iNameTranslated = i18nc("Syntax highlighting", "None"); // user > visible name > iSection = QString(); > makeNoneContext(); > } As far as I see, this never adds anything to m_contexts. Any code path that would add anything to m_contexts prevents this with if (noHl) return; However, KateHighlighting::contextNum(int n) expects that m_contexts.size() > 0. (Maybe "Q_ASSERT (0);" should be changed to something like that?) However, I do not fully understand what the code as a whole is doing, so I am not sure how to properly fix it. My guess is that one could create a minimal KateHlContext and extend KateHighlighting::makeNoneContext() to put this KateHlContext to m_contexts[0]. makeNoneContext() should add the dummy 0 context. (In reply to Christoph Cullmann from comment #5) > makeNoneContext() should add the dummy 0 context. You mean like m_contexts.push_back(0)? This would be dereferenced (i.e. segfaulting) at katedocument.cpp:5487 attribute = context->attr; This could probably be solved with a null check. However, there might be other places with the same problem. I think having a "real" KateHlContext object would be a better solution. That object could be completely defined at compile time. Created attachment 88208 [details]
proposal for a fix by adding one default KateHlContext
This patch adds a minimalistic KateHlContext to m_contexts in makeNoneContext().
With this patch applied, I cannot reproduce the crash any more.
(as far as I understand the code, freeing the memory of the new KateHlContext object already happens in other KateHighlighting methods)
I would like to hear some opinions about it. Should I add it directly to the review board?
I think the patch should be fine, please commit Now on review board:
> https://git.reviewboard.kde.org/r/119724/
The patch looks good, but as I understand, the origin of the crash comes from the fact that the Haskell indenter haskell.js *requires* haskell highlighting. If the highlighting is not Haskell, then the haskell indenter shouldn't be chosable at all. The correct fix for this is: Add in haskell.js a style, say " <language ... style="haskell"> And then in haskell.js add to the header: required-syntax-style: haskell Martin, can you confirm this would also fix the crash? Git commit 5144dfeb7c5cc6575ab3f7b63eb32c00134c51ff by Dominik Haumann. Committed on 13/08/2014 at 19:53. Pushed by dhaumann into branch 'master'. fix crash: Allow Haskell indenter only if the Highlighting provides the "haskell" style M +3 -2 src/script/data/indentation/haskell.js M +1 -1 src/syntax/data/haskell.xml http://commits.kde.org/ktexteditor/5144dfeb7c5cc6575ab3f7b63eb32c00134c51ff (In reply to Dominik Haumann from comment #10) > The correct fix for this is: > Add in haskell.js a style, say " > <language ... style="haskell"> > > And then in haskell.js add to the header: > required-syntax-style: haskell > > Martin, can you confirm this would also fix the crash? Basically yes. But at least for KDE/4.14 it must be style="Haskell" in haskell.xml and * required-syntax-style: Haskell in haskell.js. Note the capitalized H which is mandatory because the name is also capitalized. With that, it is not possible any more to select the Haskell indenter without Haskell highlighting in Kate 3.13.3, and hence the crash cannot be triggered that way any more. However I see two drawbacks: * It prevents the Curry highlighter from using the Haskell indenter. * I expect other indenters to suffer from the same problem. We just have not seen other crash reports submitted, yet. They should all be fixed. Git commit 362217788eecab105140f2790ce7a81506f2de58 by Christoph Cullmann. Committed on 14/08/2014 at 21:36. Pushed by cullmann into branch 'master'. add dummy context, always M +10 -7 src/syntax/katehighlight.cpp http://commits.kde.org/ktexteditor/362217788eecab105140f2790ce7a81506f2de58 Git commit 1876a1939df5c196e0c9afb05e4182b3859e0e47 by Christoph Cullmann. Committed on 14/08/2014 at 21:42. Pushed by cullmann into branch 'KDE/4.14'. KateHighlighting is expected to always have at least one default KateHlContext (stored in m_contexts), but with highlighting turned off, there is no such context. As a fix, add a minimalistic KateHlContext to m_contexts in makeNoneContext. Also fix two typos ("falltrhough", "resolove") in code comments when touching part/syntax/katehighlight.cpp anyway. REVIEW: 119724 M +11 -2 part/syntax/katehighlight.cpp http://commits.kde.org/kate/1876a1939df5c196e0c9afb05e4182b3859e0e47 Git commit b739b7a67882408b4378d901c38b2c88108f1312 by Christoph Cullmann. Committed on 14/08/2014 at 21:42. Pushed by cullmann into branch 'KDE/4.13'. KateHighlighting is expected to always have at least one default KateHlContext (stored in m_contexts), but with highlighting turned off, there is no such context. As a fix, add a minimalistic KateHlContext to m_contexts in makeNoneContext. Also fix two typos ("falltrhough", "resolove") in code comments when touching part/syntax/katehighlight.cpp anyway. REVIEW: 119724 M +11 -2 part/syntax/katehighlight.cpp http://commits.kde.org/kate/b739b7a67882408b4378d901c38b2c88108f1312 Do we need to do things with the hl/js file again? The context 0 fix is now in all branches, I hope, a bit different in ktexteditor.git master (In reply to Christoph Cullmann from comment #16) > Do we need to do things with the hl/js file again? > The context 0 fix is now in all branches, I hope, a bit different in > ktexteditor.git master Thanks for pushing the patches. With the style="haskell" attribute in the Haskell indenter, it is not possible to select the Haskell indenter together with any other highlighting any more, is it? This affects in particular the "Curry" and the "None" highlighting. So, I would just remove that attribute from haskell.js again. Well, what's important to understand is that the string in "style=" does not have to match the indenter or hl name. Example: haskell.js could say: required-syntax-style=abcd haskell.xml could say: style="abcd" curry.xml could say: style="abcd" And then you can choose the Haskell indenter again with Curry. Would that help already? The idea behind the "style" attribute is that indenters that rely on highlighting information won't work without highlighting. (In reply to Dominik Haumann from comment #18) > Well, what's important to understand is that the string in "style=" does not > have to match the indenter or hl name. Example: > haskell.js could say: required-syntax-style=abcd > haskell.xml could say: style="abcd" > curry.xml could say: style="abcd" Thank you for this explanation. Makes things a lot clearer. I got this totally wrong, because there was some cruft in my ~/.kde4 folder, causing strange effects like the thing about needing to capitalize the "H" of "haskell" in comment #12. > And then you can choose the Haskell indenter again with Curry. Would that > help already? Yes, this would definitely help. > The idea behind the "style" attribute is that indenters that rely on > highlighting information won't work without highlighting. In the particular case of the haskell indenter, it looks like it also works mostly with highlighting completely turned off. I guess one can argue against as well as for limiting the Haskell indenter to Haskell and Curry highlighting. Where I still see some conflicts are the Literate Curry and Literate Haskell modes. As far as I see, the haskell indenter yields bad results with those two highlighters, but I do not know enough about Haskell programming to know for sure. However, I guess there should be a clear decision whether to use the haskell indenter with the Literate modes or not. Currently, literate-curry.xml contains the attribute indenter="haskell" while literate-haskell does not (and none of them contains a style="..." attribute). Actually I think just allowing the indenter to work for any language is ok, if it doesn't crash, which is now fixed. Will just revert the syntax/js change. Git commit c1ac3e1913df556b54646eb1efc2aaa13379bb95 by Christoph Cullmann. Committed on 17/08/2014 at 19:30. Pushed by cullmann into branch 'master'. don't check for style in js file M +2 -3 src/script/data/indentation/haskell.js http://commits.kde.org/ktexteditor/c1ac3e1913df556b54646eb1efc2aaa13379bb95 Please, can you backport to KDE SC 4.12 ? Had the same issue, with a non-highlighted file. Whenever the cursor would reach the end of line, after some auto-completion, editor would crash. Just cherry-picking 44beb7d342309 and b739b7a67882408b43 fixed my 4.12 build. Git commit c2a1c24f28613342985aa40573fb922370900a3a by Dominik Haumann, on behalf of Christoph Cullmann. Committed on 14/08/2014 at 21:42. Pushed by dhaumann into branch 'KDE/4.12'. KateHighlighting is expected to always have at least one default KateHlContext (stored in m_contexts), but with highlighting turned off, there is no such context. As a fix, add a minimalistic KateHlContext to m_contexts in makeNoneContext. Also fix two typos ("falltrhough", "resolove") in code comments when touching part/syntax/katehighlight.cpp anyway. REVIEW: 119724 M +11 -2 part/syntax/katehighlight.cpp http://commits.kde.org/kate/c2a1c24f28613342985aa40573fb922370900a3a > Just cherry-picking 44beb7d342309 and b739b7a67882408b43 fixed my 4.12 build.
Done. There probably will not be a KDE 4.12.6, though... So the update will most probably not arrive in distributions.
(In reply to Dominik Haumann from comment #24) > Done. There probably will not be a KDE 4.12.6, though... So the update will > most probably not arrive in distributions. Thank you, I have filed a bug in my distro about that. |