From 8300f42e023c58edae7ca2810928fa585128ae4b Mon Sep 17 00:00:00 2001 From: apprb Date: Sat, 25 Oct 2014 01:25:28 +0900 Subject: [PATCH] Reducing memory consumption: no reason to store all displayed ChatActions in memory --- src/widget/chatareawidget.cpp | 24 +++++++++++++++++++----- src/widget/chatareawidget.h | 6 +++--- src/widget/form/chatform.cpp | 8 +------- 3 files changed, 23 insertions(+), 15 deletions(-) diff --git a/src/widget/chatareawidget.cpp b/src/widget/chatareawidget.cpp index 75c4ccc76..ee968d9f3 100644 --- a/src/widget/chatareawidget.cpp +++ b/src/widget/chatareawidget.cpp @@ -22,6 +22,7 @@ #include #include #include +#include ChatAreaWidget::ChatAreaWidget(QWidget *parent) : QTextBrowser(parent) @@ -96,14 +97,14 @@ void ChatAreaWidget::onAnchorClicked(const QUrl &url) QDesktopServices::openUrl(url); } -void ChatAreaWidget::insertMessage(ChatAction *msgAction) +void ChatAreaWidget::insertMessage(ChatAction *msgAction, QTextCursor::MoveOperation pos) { if (msgAction == nullptr) return; checkSlider(); - QTextTable *chatTextTable = getMsgTable(); + QTextTable *chatTextTable = getMsgTable(pos); QTextCursor cur = chatTextTable->cellAt(0, 2).firstCursorPosition(); cur.clearSelection(); cur.setKeepPositionOnInsert(true); @@ -115,7 +116,10 @@ void ChatAreaWidget::insertMessage(ChatAction *msgAction) msgAction->setup(cur, this); - messages.append(msgAction); + if (msgAction->isInteractive()) + messages.append(msgAction); + else + delete msgAction; } int ChatAreaWidget::getNumberOfMessages() @@ -136,7 +140,7 @@ void ChatAreaWidget::checkSlider() lockSliderToBottom = scroll && scroll->value() == scroll->maximum(); } -QTextTable *ChatAreaWidget::getMsgTable() +QTextTable *ChatAreaWidget::getMsgTable(QTextCursor::MoveOperation pos) { if (tableFrmt == nullptr) { @@ -151,7 +155,7 @@ QTextTable *ChatAreaWidget::getMsgTable() } QTextCursor tc = textCursor(); - tc.movePosition(QTextCursor::End); + tc.movePosition(pos); QTextTable *chatTextTable = tc.insertTable(1, 5, *tableFrmt); @@ -189,3 +193,13 @@ void ChatAreaWidget::clearChatArea() insertMessage(message); } } + +void ChatAreaWidget::insertMessagesTop(QList &list) +{ + std::reverse(list.begin(), list.end()); + + for (ChatAction* it : list) + { + insertMessage(it, QTextCursor::Start); + } +} diff --git a/src/widget/chatareawidget.h b/src/widget/chatareawidget.h index 9deedb6a0..6cb87ae67 100644 --- a/src/widget/chatareawidget.h +++ b/src/widget/chatareawidget.h @@ -29,8 +29,8 @@ class ChatAreaWidget : public QTextBrowser public: explicit ChatAreaWidget(QWidget *parent = 0); virtual ~ChatAreaWidget(); - void insertMessage(ChatAction *msgAction); - QList& getMesages() {return messages;} + void insertMessage(ChatAction *msgAction, QTextCursor::MoveOperation pos = QTextCursor::End); + void insertMessagesTop(QList &list); int nameColWidth() {return nameWidth;} void setNameColWidth(int w); @@ -51,7 +51,7 @@ private slots: private: void checkSlider(); - QTextTable* getMsgTable(); + QTextTable* getMsgTable(QTextCursor::MoveOperation pos = QTextCursor::End); QTextTableFormat* tableFrmt; QList messages; diff --git a/src/widget/form/chatform.cpp b/src/widget/form/chatform.cpp index 9bb18e46d..cbfbff437 100644 --- a/src/widget/form/chatform.cpp +++ b/src/widget/form/chatform.cpp @@ -588,18 +588,12 @@ void ChatForm::onLoadHistory() } previousName = storedPrevName; - for (ChatAction *ca : chatWidget->getMesages()) - historyMessages.append(ca); - int savedSliderPos = chatWidget->verticalScrollBar()->maximum() - chatWidget->verticalScrollBar()->value(); - chatWidget->getMesages().clear(); - chatWidget->clear(); if (earliestMessage != nullptr) *earliestMessage = fromTime; - for (ChatAction *ca : historyMessages) - chatWidget->insertMessage(ca); + chatWidget->insertMessagesTop(historyMessages); savedSliderPos = chatWidget->verticalScrollBar()->maximum() - savedSliderPos; chatWidget->verticalScrollBar()->setValue(savedSliderPos);