From 08ea7232f711f1b14d20ae115911d7d33385bc99 Mon Sep 17 00:00:00 2001 From: thunder2 Date: Thu, 3 Jun 2010 22:12:07 +0000 Subject: [PATCH] bugfix in MessageDialog, rs could crash when removing two or more messages at once git-svn-id: http://svn.code.sf.net/p/retroshare/code/trunk@3057 b45a01b8-16f6-495d-af2f-9b41ad6348cc --- retroshare-gui/src/gui/MessagesDialog.cpp | 63 +++++++++++++++++------ retroshare-gui/src/gui/MessagesDialog.h | 12 +++++ 2 files changed, 58 insertions(+), 17 deletions(-) diff --git a/retroshare-gui/src/gui/MessagesDialog.cpp b/retroshare-gui/src/gui/MessagesDialog.cpp index 0ae002409..5f907c645 100644 --- a/retroshare-gui/src/gui/MessagesDialog.cpp +++ b/retroshare-gui/src/gui/MessagesDialog.cpp @@ -156,6 +156,23 @@ protected: } }; +MessagesDialog::LockUpdate::LockUpdate (MessagesDialog *pDialog, bool bUpdate) +{ + m_pDialog = pDialog; + m_bUpdate = bUpdate; + + m_pDialog->m_nLockUpdate++; +} + +MessagesDialog::LockUpdate::~LockUpdate () +{ + m_pDialog->m_nLockUpdate = qMax (--m_pDialog->m_nLockUpdate, 0); + + if (m_bUpdate && m_pDialog->m_nLockUpdate == 0) { + m_pDialog->insertMessages(); + } +} + static int FilterColumnFromComboBox(int nIndex) { switch (nIndex) { @@ -205,6 +222,7 @@ MessagesDialog::MessagesDialog(QWidget *parent) m_bProcessSettings = false; m_bInChange = false; + m_nLockUpdate = 0; m_pConfig = new RSettings (CONFIG_FILE); connect( ui.messagestreeView, SIGNAL( customContextMenuRequested( QPoint ) ), this, SLOT( messageslistWidgetCostumPopupMenu( QPoint ) ) ); @@ -1216,6 +1234,10 @@ static void InitIconAndFont(RSettings *pConfig, QStandardItem *pItem [COLUMN_COU void MessagesDialog::insertMessages() { + if (m_nLockUpdate) { + return; + } + std::cerr <<"MessagesDialog::insertMessages called"; fflush(0); @@ -1914,6 +1936,8 @@ bool MessagesDialog::getCurrentMsg(std::string &cid, std::string &mid) void MessagesDialog::removemessage() { + LockUpdate Lock (this, true); + QList selectedIndexList= ui.messagestreeView->selectionModel() -> selectedIndexes (); QList rowList; QModelIndex selectedIndex; @@ -1928,7 +1952,7 @@ void MessagesDialog::removemessage() } bool bDelete = false; - int listrow = ui.listWidget -> currentRow(); + int listrow = ui.listWidget->currentRow(); if (listrow == ROW_TRASHBOX) { bDelete = true; } else { @@ -1937,30 +1961,35 @@ void MessagesDialog::removemessage() } } - for(QList::const_iterator it1(rowList.begin());it1!=rowList.end();++it1) { - QString mid = MessagesModel->item((*it1),COLUMN_MSGID)->text(); - if (bDelete) { - rsMsgs->MessageDelete(mid.toStdString()); + for(QList::const_iterator it1 = rowList.begin(); it1 != rowList.end(); it1++) { + QStandardItem *pItem = MessagesModel->item((*it1), COLUMN_MSGID); + if (pItem) { + QString mid = pItem->text(); + if (bDelete) { + rsMsgs->MessageDelete(mid.toStdString()); - // clean locale config - m_pConfig->beginGroup(CONFIG_SECTION_UNREAD); - m_pConfig->remove (mid); - m_pConfig->endGroup(); + // clean locale config + m_pConfig->beginGroup(CONFIG_SECTION_UNREAD); + m_pConfig->remove (mid); + m_pConfig->endGroup(); - // remove tag - m_pConfig->beginGroup(CONFIG_SECTION_TAG); - m_pConfig->remove (mid); - m_pConfig->endGroup(); - } else { - rsMsgs->MessageToTrash(mid.toStdString(), true); + // remove tag + m_pConfig->beginGroup(CONFIG_SECTION_TAG); + m_pConfig->remove (mid); + m_pConfig->endGroup(); + } else { + rsMsgs->MessageToTrash(mid.toStdString(), true); + } } } - insertMessages(); + // LockUpdate -> insertMessages(); } void MessagesDialog::undeletemessage() { + LockUpdate (this, true); + QList Rows; getSelectedMsgCount (&Rows, NULL, NULL); for (int nRow = 0; nRow < Rows.size(); nRow++) { @@ -1968,7 +1997,7 @@ void MessagesDialog::undeletemessage() rsMsgs->MessageToTrash(mid.toStdString(), false); } - insertMessages(); + // LockUpdate -> insertMessages(); } void MessagesDialog::print() diff --git a/retroshare-gui/src/gui/MessagesDialog.h b/retroshare-gui/src/gui/MessagesDialog.h index 32a3c51f4..6d7f953c9 100644 --- a/retroshare-gui/src/gui/MessagesDialog.h +++ b/retroshare-gui/src/gui/MessagesDialog.h @@ -123,6 +123,17 @@ private slots: #endif private: + class LockUpdate + { + public: + LockUpdate (MessagesDialog *pDialog, bool bUpdate); + ~LockUpdate (); + + private: + MessagesDialog *m_pDialog; + bool m_bUpdate; + }; + class QStandardItemModel *MessagesModel; QSortFilterProxyModel *proxyModel; @@ -147,6 +158,7 @@ private: #endif bool m_bProcessSettings; bool m_bInChange; + int m_nLockUpdate; // use with LockUpdate enum { LIST_NOTHING, LIST_BOX,