<table><tr><td style="">broulik created this revision.<br />broulik added a reviewer: Plasma.<br />Herald added a project: Plasma.<br />Herald added a subscriber: plasma-devel.<br />broulik requested review of this revision.
</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/D22735">View Revision</a></tr></table><br /><div><strong>REVISION SUMMARY</strong><div><p>This adds a new <tt style="background: #ebebeb; font-size: 13px;">Milou.ResultsModel</tt> for runner results which tries very hard to avoid model resets and instead signals addition, removal, and changes in results.<br />
The various result processing, filtering, and grouping features are split into tiny dedicated proxy models to make the code easier to follow and maintain. The QML API isn't changed so that look and feel themes don't need to be adjusted.</p>

<p>The raw results model is a tree of runner results grouped by <tt style="background: #ebebeb; font-size: 13px;">matchCategory</tt> (e.g. "Documents", "Applications").<br />
Results are then sorted by result type (<tt style="background: #ebebeb; font-size: 13px;">ExactMatch</tt>, <tt style="background: #ebebeb; font-size: 13px;">HelperMatch</tt>, etc) and by their <tt style="background: #ebebeb; font-size: 13px;">relevance</tt>. The highest scored match in a group determines its overall score. The previous heuristic of prefering categories who have results with the query in their visible text has been removed but could easily be added back if deemed beneficial for the quality of results.</p>

<p>The groups are then limited in size with higher scored categories being allowed to show more matches. This model could in the future also be extended to allow expanding groups to show all of the results inside.<br />
After that the model is flattened back into a tree with the group items removed for consumption in the existing <tt style="background: #ebebeb; font-size: 13px;">ListView</tt>. Items with an identical <tt style="background: #ebebeb; font-size: 13px;">text</tt> will have their <tt style="background: #ebebeb; font-size: 13px;">subtext</tt> displayed automatically for disambiguation.</p></div></div><br /><div><strong>TEST PLAN</strong><div><ul class="remarkup-list">
<li class="remarkup-list-item">KRunner feels snappier overall, especially when dealing with a result set that hardly changes, e.g. using the calculator runner</li>
<li class="remarkup-list-item">Ran model test and fixed most of its complaints. However, when updating a category, we append the new items, replace the entire list, and afterwards signal a data change, which model test doesn't like. It checks for whether the data before the inserted area didn't change, which it did at this point but that's why we signal a data change afterwards :)</li>
</ul>

<ul class="remarkup-list">
<li class="remarkup-list-item">Running results still works</li>
<li class="remarkup-list-item">Replacing the query string when requested still works, e.g. clicking on a calculator runner result changes the query string to that number</li>
<li class="remarkup-list-item">Dragging results from KRunner to elsewhere still works. I noticed dragging applications from krunner to kickoff doesn't work but didn't check if that is a regression or because KRunner closes when kickoff opens</li>
<li class="remarkup-list-item">Invoking runner actions (e.g. "run in terminal") still work</li>
</ul></div></div><br /><div><strong>REPOSITORY</strong><div><div>R112 Milou</div></div></div><br /><div><strong>REVISION DETAIL</strong><div><a href="https://phabricator.kde.org/D22735">https://phabricator.kde.org/D22735</a></div></div><br /><div><strong>AFFECTED FILES</strong><div><div>CMakeLists.txt<br />
lib/CMakeLists.txt<br />
lib/qml/ResultDelegate.qml<br />
lib/qml/ResultsView.qml<br />
lib/qml/qmlplugins.cpp<br />
lib/resultsmodel.cpp<br />
lib/resultsmodel.h<br />
lib/runnerresultsmodel.cpp<br />
lib/runnerresultsmodel.h</div></div></div><br /><div><strong>To: </strong>broulik, Plasma<br /><strong>Cc: </strong>plasma-devel, LeGast00n, jraleigh, fbampaloukas, GB_2, ragreen, Pitel, ZrenBot, himcesjf, lesliezhai, ali-mohamed, jensreuterberg, abetts, sebas, apol, mart<br /></div>