<table><tr><td style="">rrosch added a comment.
</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/D25315">View Revision</a></tr></table><br /><div><div><p>Tested on patched KF5 5.64, on Fedora 30 (32bit)... root node shows up! I had to change the call in my code that was originally:</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);">model->dirLister()->openUrl(QUrl::fromLocalFile("/"), KDirLister::Keep);</pre></div>

<p>to</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);">model->openUrl(QUrl::fromLocalFile("/"), KDirModel::ShowRoot);</pre></div>

<p>and don't really know the implications of the change at this point. (Will it "Keep"? Does it matter that I now call the model's openURL vs the dirLister's?)</p>

<p>I couldn't however get the following to work:</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);">QModelIndex index = getIndexFromUrl("/home/myuser");
if (index.isValid()) {
    treeView->setRootIndex(index.parent());
}</pre></div>

<p>Which should show the node for "/home" as the root, but is instead giving me a flat listing of all the child nodes without "/home" as the root. Am I doing something wrong here? That part is called on a slot for the signal <tt style="background: #ebebeb; font-size: 13px;">&KDirModel::expand</tt>. (Also, it would be great to have a setRootPath() that works in conjunction to expandToUrl or openUrl, to save processing cycles wasted on loading the parts of the model that won't be shown in the new rootIndex, like <a href="https://doc.qt.io/qt-5/qfilesystemmodel.html#setRootPath" class="remarkup-link" target="_blank" rel="noreferrer">https://doc.qt.io/qt-5/qfilesystemmodel.html#setRootPath</a> )</p>

<p>As it is relevant, I also tested the patch at <a href="http://www.davidfaure.fr/2019/kdirmodel_haschildren.diff" class="remarkup-link" target="_blank" rel="noreferrer">http://www.davidfaure.fr/2019/kdirmodel_haschildren.diff</a> for <tt style="background: #ebebeb; font-size: 13px;">hasChildren()</tt>, which works as expected! Thank you!</p>

<hr class="remarkup-hr" />

<p>For the curious, I just downloaded the source rpm for <tt style="background: #ebebeb; font-size: 13px;">kf5-kio</tt>, installed it as unprivileged user, edited the .spec file to include the raw diff here as a the <em>second</em> patch, and the raw diff for <a href="https://phabricator.kde.org/D25249" style="background-color: #e7e7e7;
          border-color: #e7e7e7;
          border-radius: 3px;
          padding: 0 4px;
          font-weight: bold;
          color: black;text-decoration: line-through;">D25249</a> as the <em>first</em> patch (and copying them to <tt style="background: #ebebeb; font-size: 13px;">~/rpmbuild/SOURCES/</tt> of course). I also had to change the <tt style="background: #ebebeb; font-size: 13px;">Release: </tt> line to something greater than the one already there so it installs without conflicts (I changed mine from "1" to "2patched"). Then just</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);">rpmbuild -bb ~/rpmbuild/SPECS/kf5-kio.spec</pre></div>

<p>and install the relevant rpms. No need to rebuild all of KF5 from git (which I started to attempt and bailed pretty quickly after thinking this might be the easier/faster/less space-using way. Knowing this process will be useful for newcomers to help test features on their system without the daunting (and probably impossible due to limited space) task of compiling all of KF5. This could be added to the dev documentation somewhere.</p>

<p>In any case, thanks again for implementing the feature! (Next step is to try to follow the same procedure to test the "crash on close of view" fix you submitted for Qt5, thanks also for that!)</p></div></div><br /><div><strong>REPOSITORY</strong><div><div>R241 KIO</div></div></div><br /><div><strong>REVISION DETAIL</strong><div><a href="https://phabricator.kde.org/D25315">https://phabricator.kde.org/D25315</a></div></div><br /><div><strong>To: </strong>dfaure, stefanocrocco, elvisangelaccio, meven, apol<br /><strong>Cc: </strong>rrosch, kde-frameworks-devel, LeGast00n, cblack, GB_2, michaelh, ngraham, bruns<br /></div>