<table><tr><td style="">sitter 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/D22528">View Revision</a></tr></table><br /><div><div><p>Hm. I've had a quick look and I think the intent was that only the slavebase overridden functions call error or finished. So technically all internal functions that can have an error need to set an iError or return one so that the "public" function can then issue error() as needed. This seems to not very well enforced and probably never was, in fact there's a comment in the .h about this very fact</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);">// ------------------------------------------------------------------------
// All the methods named ftpXyz are lowlevel methods that are not exported.
// The implement functionality used by the public high-level methods. Some
// low-level methods still use error() to emit errors. This behaviour is not
// recommended - please return a boolean status or an error code instead!
// ------------------------------------------------------------------------</pre></div>
<p>What I think may be best to resolve this is to split the class in two.</p>
<p>The "public" class only has overrides of SlaveBase. It's functions are the only ones that may issue <tt style="background: #ebebeb; font-size: 13px;">error()</tt> or <tt style="background: #ebebeb; font-size: 13px;">finished()</tt>.<br />
The "private" class has all the supporting functions and has no access to SlaveBase so it cannot issue error or finished.<br />
This should be a very durable solution as even in the future no one will accidentally add another call to error or finished in one of the internal functions since they are in a different object and all error handling must be done via iError or some other system.</p>
<p>In fact, I am thinking this is a case where one could just use exceptions. The private class could throw a simple exception on errors and in the public class we'd need nothing more than a try{}catch in all the public functions.</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/D22528">https://phabricator.kde.org/D22528</a></div></div><br /><div><strong>To: </strong>ZaWertun, sitter, dfaure, cfeck<br /><strong>Cc: </strong>kde-frameworks-devel, LeGast00n, sbergeron, michaelh, ngraham, bruns<br /></div>