ResMed crash fix - Not a good idea to remove sessions while iterating through them

This commit is contained in:
Mark Watkins 2018-05-31 10:27:44 +10:00
parent a3b5026fd7
commit b8475ac970
2 changed files with 8 additions and 9 deletions

View File

@ -1293,6 +1293,7 @@ qint64 Day::last(MachineType type)
bool Day::removeSession(Session *sess)
{
sess->machine()->sessionlist.remove(sess->session());
MachineType mt = sess->type();
bool b = sessions.removeAll(sess) > 0;
if (!searchMachine(mt)) {

View File

@ -1547,9 +1547,9 @@ struct OverlappingEDF {
void ResDayTask::run()
{
if (this->resday->date == QDate(2016,1,6)) {
qDebug() << "in resday" << this->resday->date;
}
// if (this->resday->date == QDate(2016,1,6)) {
// qDebug() << "in resday" << this->resday->date;
// }
/*loader->sessionMutex.lock();
Day *day = p_profile->FindDay(resday->date, MT_CPAP);
if (day) {
@ -2192,12 +2192,10 @@ int ResmedLoader::Open(const QString & dirpath)
// but the worst case scenario is this session is deleted and reimported.. this just slows things down a bit in that case
// This day was first imported as a summary from STR.edf, so we now totally want to redo this day
for (auto & sess : day->sessions) {
if (sess->type() == MT_CPAP) {
day->removeSession(sess);
mach->sessionlist.remove(sess->session());
delete sess;
}
QList<Session *> sessions = day->getSessions(MT_CPAP);
for (auto & sess : sessions) {
day->removeSession(sess);
delete sess;
}
reimporting = true;