<table><tr><td style="">asemke requested changes to this revision.<br />asemke added a comment.<br />This revision now requires changes to proceed.
</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/D16663">View Revision</a></tr></table><br /><div><div><p><a href="https://phabricator.kde.org/p/croick/" style="
              border-color: #f1f7ff;
              color: #19558d;
              background-color: #f1f7ff;
                border: 1px solid transparent;
                border-radius: 3px;
                font-weight: bold;
                padding: 0 4px;">@croick</a> thanks for addressing this. The memory leaks ImportFileWidget::currentFilter() are known for long time already but we didn't manage to clean up here yet... Thanks for addressing this now!</p>

<p>Couple of comments</p>

<ul class="remarkup-list">
<li class="remarkup-list-item">QSharedPointer has additional overhead for reference counting which we don't need in this case. Can we use std::unique_ptr here?</li>
<li class="remarkup-list-item">The new function AbstractFileFilter::type() can be implemented in the base class only with</li>
</ul>

<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);">FileType AbstractFileFilter::type() {
    return m_type;
}</pre></div>

<p>where m_type is a protected member in AbstractFileFilter which is initialized in the constructors of the different file filter classes. With this we don't need implemented this function in every filter class and to touch all header files.</p>

<ul class="remarkup-list">
<li class="remarkup-list-item">In LabPlot we very frequently use  raw pointers as function parameters since the ownership and the life cycle  of them is very clear. For objects that only read the content of such pointers there is no need to use smart pointers to transfer the ownership or to do the reference counting. updateContent() in the options widgets is also such a case where we don't need any ref-counting and where a raw pointer is totally fine.</li>
</ul></div></div><br /><div><strong>REPOSITORY</strong><div><div>R262 LabPlot</div></div></div><br /><div><strong>REVISION DETAIL</strong><div><a href="https://phabricator.kde.org/D16663">https://phabricator.kde.org/D16663</a></div></div><br /><div><strong>To: </strong>croick, LabPlot, asemke<br /><strong>Cc: </strong>asemke, kde-edu, narvaez, apol<br /></div>