<table><tr><td style="">poboiko created this revision.<br />poboiko added reviewers: Frameworks, dvratil, apol.<br />Herald added a project: Frameworks.<br />Herald added a subscriber: kde-frameworks-devel.<br />poboiko 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/D15812">View Revision</a></tr></table><br /><div><strong>REVISION SUMMARY</strong><div><p>Currently, right after removing a person (which i.e. removes it from personIndex), we call personChanged.<br />
Which itself tries to access personIndex with recently removed key, which creates a default (invalid) value with such key.<br />
In the end we obtain inconsistent (invalid) index, which leads to crash.</p></div></div><br /><div><strong>TEST PLAN</strong><div><p>I've noted the bug when was working on <a href="https://phabricator.kde.org/T9595" style="background-color: #e7e7e7;
border-color: #e7e7e7;
border-radius: 3px;
padding: 0 4px;
font-weight: bold;
color: black;text-decoration: none;">T9595: [KAddressbook] Use KPeople model for contact list</a>, see <a href="https://cgit.kde.org/scratch/poboiko/akonadi-kpeople-plugin.git/" class="remarkup-link" target="_blank" rel="noreferrer">scratch repo</a> and "testab" application there.<br />
It's sufficient to check/uncheck address books several times to crash it.<br />
After applying this patch, it no longer crashes.</p></div></div><br /><div><strong>REPOSITORY</strong><div><div>R307 KPeople</div></div></div><br /><div><strong>BRANCH</strong><div><div>person-remove (branched from master)</div></div></div><br /><div><strong>REVISION DETAIL</strong><div><a href="https://phabricator.kde.org/D15812">https://phabricator.kde.org/D15812</a></div></div><br /><div><strong>AFFECTED FILES</strong><div><div>src/personsmodel.cpp</div></div></div><br /><div><strong>To: </strong>poboiko, Frameworks, dvratil, apol<br /><strong>Cc: </strong>kde-frameworks-devel, michaelh, ngraham, bruns<br /></div>