<table><tr><td style="">dfaure created this revision.<br />dfaure added reviewers: sandsmark, mlaurent.<br />Restricted Application added a project: Frameworks.
</td><a style="text-decoration: none; padding: 4px 8px; margin: 0 8px 8px; float: right; color: #464C5C; font-weight: bold; border-radius: 3px; background-color: #F7F7F9; background-image: linear-gradient(to bottom,#fff,#f1f0f1); display: inline-block; border: 1px solid rgba(71,87,120,.2);" href="https://phabricator.kde.org/D9491" rel="noreferrer">View Revision</a></tr></table><br /><div><strong>REVISION SUMMARY</strong><div><p>When AutoDetectLanguage is set, the same document can contain multiple<br />
languages. In that case, Highlighter stores the language information<br />
into the block's userdata, and changes the spellchecker language at<br />
every change. So the suggestions were using whatever was the language<br />
of the last block that was checked, which led to pretty random behaviour<br />
for the user.</p>

<p>Fixed by using a QTextCursor to retrieve the cached language for the<br />
word we're showing suggestions for.</p>

<p>Includes a separate commit for Loader:</p>

<div class="remarkup-code-block" style="margin: 12px 0;" data-code-lang="text" data-sigil="remarkup-code-block"><pre class="remarkup-code" style="font: 11px/15px "Menlo", "Consolas", "Monaco", monospace; padding: 12px; margin: 0; background: rgba(71, 87, 120, 0.08);">honour Settings::defaultClient(), useful for unittests.</pre></div></div></div><br /><div><strong>TEST PLAN</strong><div><p>Spellchecking in kmail composer, writing text in French<br />
and having a signature with word in English.</p></div></div><br /><div><strong>REPOSITORY</strong><div><div>R246 Sonnet</div></div></div><br /><div><strong>BRANCH</strong><div><div>master</div></div></div><br /><div><strong>REVISION DETAIL</strong><div><a href="https://phabricator.kde.org/D9491" rel="noreferrer">https://phabricator.kde.org/D9491</a></div></div><br /><div><strong>AFFECTED FILES</strong><div><div>autotests/CMakeLists.txt<br />
autotests/test_highlighter.cpp<br />
src/core/loader.cpp<br />
src/ui/highlighter.cpp<br />
src/ui/highlighter.h<br />
src/ui/spellcheckdecorator.cpp</div></div></div><br /><div><strong>To: </strong>dfaure, sandsmark, mlaurent<br /><strong>Cc: </strong>KDE PIM, Frameworks<br /></div>