<table><tr><td style="">sredman 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/D16475">View Revision</a></tr></table><br /><div><div><blockquote style="border-left: 3px solid #8C98B8;
color: #6B748C;
font-style: italic;
margin: 4px 0 12px 0;
padding: 8px 12px;
background-color: #F8F9FC;">
<div style="font-style: normal;
padding-bottom: 4px;">In <a href="https://phabricator.kde.org/D16475#358422" style="background-color: #e7e7e7;
border-color: #e7e7e7;
border-radius: 3px;
padding: 0 4px;
font-weight: bold;
color: black;text-decoration: none;">D16475#358422</a>, <a href="https://phabricator.kde.org/p/apol/" style="
border-color: #f1f7ff;
color: #19558d;
background-color: #f1f7ff;
border: 1px solid transparent;
border-radius: 3px;
font-weight: bold;
padding: 0 4px;">@apol</a> wrote:</div>
<div style="margin: 0;
padding: 0;
border: 0;
color: rgb(107, 116, 140);"><p>I would be okay with accepting this patch. I wonder why it's better than the previous code though. It seems to be just doing the same but from another thread?</p></div>
</blockquote>
<p>By previous code, do you mean the earlier version of this patch or the stuff currently on the master branch?</p>
<p>In case of comparing to the earlier version, it is basically the same, but no new threads have been created. The work in the constructor (even after <tt style="background: #ebebeb; font-size: 13px;">this->moveToThread(..)</tt>) is all done on the main thread. Future signals delivered to the Worker object are handled on the new thread.</p>
<p>In case of comparing to the master branch, the new thread is doing the same work, but it also blocks (in ConversationsDbusInterface::updateConversation) while it waits for messages to be delivered from the remote device. The alternatives to blocking are:</p>
<ul class="remarkup-list">
<li class="remarkup-list-item">Return immediately, only using the messages currently cached. On the first try, this will be no messages, but the request will be delivered to the phone and handled. If the user of the SMS app waits until that request is handled and tries to load messages again, there will be cached messages the second try. This is not a very nice user experience.</li>
<li class="remarkup-list-item">Return immediately, only using the messages currently cached. On the first try, this will be no messages. As the phone replies with its messages, immediately announce them on dbus. The first time the user opens a conversation in the messaging app, every message in the conversation will be shown (after a quick delay). When opening future times, the cache will be populated, so only the requested messages will be shown. This is also kind of ugly.</li>
</ul></div></div><br /><div><strong>REPOSITORY</strong><div><div>R224 KDE Connect</div></div></div><br /><div><strong>REVISION DETAIL</strong><div><a href="https://phabricator.kde.org/D16475">https://phabricator.kde.org/D16475</a></div></div><br /><div><strong>To: </strong>sredman, KDE Connect<br /><strong>Cc: </strong>apol, nicolasfella, kdeconnect, shivanshukantprasad, skymoore, wistak, dvalencia, rmenezes, julioc, Leptopoda, timothyc, jdvr, Danial0_0, johnq, Pitel, adeen-s, SemperPeritus, daniel.z.tg, jeanv, seebauer, bugzy, MayeulC, menasshock, mikesomov, tctara<br /></div>