From d94712b2e2719960959fa0ded0ce056b2fc86c30 Mon Sep 17 00:00:00 2001 From: iphydf Date: Fri, 23 Sep 2016 03:06:20 +0100 Subject: [PATCH] refactor: Avoid RTTI by using qobject_cast. This allows us to save some memory and executable size by removing the need to generate and compile C++ RTTI. --- src/chatlog/chatlinecontent.h | 5 ++++- src/chatlog/chatlinecontentproxy.h | 2 ++ src/chatlog/chatlog.cpp | 4 ++-- src/chatlog/content/notificationicon.h | 2 +- src/chatlog/content/spinner.h | 2 +- src/chatlog/content/timestamp.h | 1 + src/widget/categorywidget.cpp | 6 +++--- src/widget/circlewidget.cpp | 8 ++++---- src/widget/contentdialog.cpp | 2 +- src/widget/form/genericchatform.cpp | 4 ++-- src/widget/friendlistlayout.cpp | 4 ++-- src/widget/friendlistwidget.cpp | 20 ++++++++++---------- src/widget/friendwidget.cpp | 4 ++-- src/widget/genericchatitemlayout.cpp | 8 ++++---- 14 files changed, 39 insertions(+), 33 deletions(-) diff --git a/src/chatlog/chatlinecontent.h b/src/chatlog/chatlinecontent.h index 778095158..41f80e622 100644 --- a/src/chatlog/chatlinecontent.h +++ b/src/chatlog/chatlinecontent.h @@ -24,8 +24,11 @@ class ChatLine; -class ChatLineContent : public QGraphicsItem +class ChatLineContent : public QObject, public QGraphicsItem { + Q_OBJECT + Q_INTERFACES(QGraphicsItem) + public: enum GraphicsItemType { diff --git a/src/chatlog/chatlinecontentproxy.h b/src/chatlog/chatlinecontentproxy.h index a4f49f902..d1ad72db6 100644 --- a/src/chatlog/chatlinecontentproxy.h +++ b/src/chatlog/chatlinecontentproxy.h @@ -27,6 +27,8 @@ class FileTransferWidget; class ChatLineContentProxy : public ChatLineContent { + Q_OBJECT + public: enum ChatLineContentProxyType { diff --git a/src/chatlog/chatlog.cpp b/src/chatlog/chatlog.cpp index 836b8b14b..a0be24763 100644 --- a/src/chatlog/chatlog.cpp +++ b/src/chatlog/chatlog.cpp @@ -868,12 +868,12 @@ bool ChatLog::isActiveFileTransfer(ChatLine::Ptr l) for (int i = 0; i < count; i++) { ChatLineContent *content = l->getContent(i); - ChatLineContentProxy *proxy = dynamic_cast(content); + ChatLineContentProxy *proxy = qobject_cast(content); if (!proxy) continue; QWidget *widget = proxy->getWidget(); - FileTransferWidget *transferWidget = dynamic_cast(widget); + FileTransferWidget *transferWidget = qobject_cast(widget); if (transferWidget && transferWidget->isActive()) return true; } diff --git a/src/chatlog/content/notificationicon.h b/src/chatlog/content/notificationicon.h index e918e6a74..b40cc7a46 100644 --- a/src/chatlog/content/notificationicon.h +++ b/src/chatlog/content/notificationicon.h @@ -27,7 +27,7 @@ class QTimer; -class NotificationIcon : public QObject, public ChatLineContent +class NotificationIcon : public ChatLineContent { Q_OBJECT public: diff --git a/src/chatlog/content/spinner.h b/src/chatlog/content/spinner.h index d83b4b537..efb205ec6 100644 --- a/src/chatlog/content/spinner.h +++ b/src/chatlog/content/spinner.h @@ -28,7 +28,7 @@ class QVariantAnimation; -class Spinner : public QObject, public ChatLineContent +class Spinner : public ChatLineContent { Q_OBJECT public: diff --git a/src/chatlog/content/timestamp.h b/src/chatlog/content/timestamp.h index ae5ad86ac..285b83ade 100644 --- a/src/chatlog/content/timestamp.h +++ b/src/chatlog/content/timestamp.h @@ -25,6 +25,7 @@ class Timestamp : public Text { + Q_OBJECT public: Timestamp(const QDateTime& time, const QString& format, const QFont& font); QDateTime getTime(); diff --git a/src/widget/categorywidget.cpp b/src/widget/categorywidget.cpp index 73ca47452..3e93a7375 100644 --- a/src/widget/categorywidget.cpp +++ b/src/widget/categorywidget.cpp @@ -30,7 +30,7 @@ void CategoryWidget::emitChatroomWidget(QLayout* layout, int index) { - GenericChatroomWidget* chatWidget = dynamic_cast(layout->itemAt(index)->widget()); + GenericChatroomWidget* chatWidget = qobject_cast(layout->itemAt(index)->widget()); if (chatWidget != nullptr) emit chatWidget->chatroomWidgetClicked(chatWidget); } @@ -199,7 +199,7 @@ bool CategoryWidget::cycleContacts(FriendWidget* activeChatroomWidget, bool forw int index = -1; QLayout* currentLayout = nullptr; - FriendWidget* friendWidget = dynamic_cast(activeChatroomWidget); + FriendWidget* friendWidget = qobject_cast(activeChatroomWidget); if (friendWidget == nullptr) return false; @@ -236,7 +236,7 @@ bool CategoryWidget::cycleContacts(FriendWidget* activeChatroomWidget, bool forw continue; } - GenericChatroomWidget* chatWidget = dynamic_cast(currentLayout->itemAt(index)->widget()); + GenericChatroomWidget* chatWidget = qobject_cast(currentLayout->itemAt(index)->widget()); if (chatWidget != nullptr) emit chatWidget->chatroomWidgetClicked(chatWidget); return true; diff --git a/src/widget/circlewidget.cpp b/src/widget/circlewidget.cpp index a0c83701b..926f8f1f8 100644 --- a/src/widget/circlewidget.cpp +++ b/src/widget/circlewidget.cpp @@ -121,7 +121,7 @@ void CircleWidget::contextMenuEvent(QContextMenuEvent* event) for (int i = 0; i < friendOnlineLayout()->count(); ++i) { - FriendWidget* friendWidget = dynamic_cast(friendOnlineLayout()->itemAt(i)->widget()); + FriendWidget* friendWidget = qobject_cast(friendOnlineLayout()->itemAt(i)->widget()); if (friendWidget != nullptr) { @@ -131,7 +131,7 @@ void CircleWidget::contextMenuEvent(QContextMenuEvent* event) } for (int i = 0; i < friendOfflineLayout()->count(); ++i) { - FriendWidget* friendWidget = dynamic_cast(friendOfflineLayout()->itemAt(i)->widget()); + FriendWidget* friendWidget = qobject_cast(friendOfflineLayout()->itemAt(i)->widget()); if (friendWidget != nullptr) { @@ -219,14 +219,14 @@ void CircleWidget::updateID(int index) for (int i = 0; i < friendOnlineLayout()->count(); ++i) { - FriendWidget* friendWidget = dynamic_cast(friendOnlineLayout()->itemAt(i)->widget()); + FriendWidget* friendWidget = qobject_cast(friendOnlineLayout()->itemAt(i)->widget()); if (friendWidget != nullptr) Settings::getInstance().setFriendCircleID(FriendList::findFriend(friendWidget->friendId)->getToxId(), id); } for (int i = 0; i < friendOfflineLayout()->count(); ++i) { - FriendWidget* friendWidget = dynamic_cast(friendOfflineLayout()->itemAt(i)->widget()); + FriendWidget* friendWidget = qobject_cast(friendOfflineLayout()->itemAt(i)->widget()); if (friendWidget != nullptr) Settings::getInstance().setFriendCircleID(FriendList::findFriend(friendWidget->friendId)->getToxId(), id); diff --git a/src/widget/contentdialog.cpp b/src/widget/contentdialog.cpp index 2622dff47..f1b29f037 100644 --- a/src/widget/contentdialog.cpp +++ b/src/widget/contentdialog.cpp @@ -358,7 +358,7 @@ void ContentDialog::cycleContacts(bool forward, bool loop) continue; } - GenericChatroomWidget* chatWidget = dynamic_cast(currentLayout->itemAt(index)->widget()); + GenericChatroomWidget* chatWidget = qobject_cast(currentLayout->itemAt(index)->widget()); if (chatWidget != nullptr && chatWidget != activeChatroomWidget) onChatroomWidgetClicked(chatWidget, false); diff --git a/src/widget/form/genericchatform.cpp b/src/widget/form/genericchatform.cpp index 678542b8c..dd85b7872 100644 --- a/src/widget/form/genericchatform.cpp +++ b/src/widget/form/genericchatform.cpp @@ -265,7 +265,7 @@ QDate GenericChatForm::getLatestDate() const if (chatLine) { - Timestamp* timestamp = dynamic_cast(chatLine->getContent(2)); + Timestamp* timestamp = qobject_cast(chatLine->getContent(2)); if (timestamp) return timestamp->getTime().date(); @@ -409,7 +409,7 @@ void GenericChatForm::onSaveLogClicked() auto lines = chatWidget->getLines(); for (ChatLine::Ptr l : lines) { - Timestamp* rightCol = dynamic_cast(l->getContent(2)); + Timestamp* rightCol = qobject_cast(l->getContent(2)); if (!rightCol) return; diff --git a/src/widget/friendlistlayout.cpp b/src/widget/friendlistlayout.cpp index 6901f7047..522163a25 100644 --- a/src/widget/friendlistlayout.cpp +++ b/src/widget/friendlistlayout.cpp @@ -81,14 +81,14 @@ void FriendListLayout::moveFriendWidgets(FriendListWidget* listWidget) { QWidget* getWidget = friendOnlineLayout.getLayout()->takeAt(0)->widget(); - FriendWidget* friendWidget = dynamic_cast(getWidget); + FriendWidget* friendWidget = qobject_cast(getWidget); listWidget->moveWidget(friendWidget, FriendList::findFriend(friendWidget->friendId)->getStatus(), true); } while (friendOfflineLayout.getLayout()->count() != 0) { QWidget* getWidget = friendOfflineLayout.getLayout()->takeAt(0)->widget(); - FriendWidget* friendWidget = dynamic_cast(getWidget); + FriendWidget* friendWidget = qobject_cast(getWidget); listWidget->moveWidget(friendWidget, FriendList::findFriend(friendWidget->friendId)->getStatus(), true); } } diff --git a/src/widget/friendlistwidget.cpp b/src/widget/friendlistwidget.cpp index f8c8472e6..f6a656171 100644 --- a/src/widget/friendlistwidget.cpp +++ b/src/widget/friendlistwidget.cpp @@ -296,13 +296,13 @@ void FriendListWidget::setMode(Mode mode) { QDate activityDate = getDateFriend(contact); Time time = getTime(activityDate); - CategoryWidget* categoryWidget = dynamic_cast(activityLayout->itemAt(time)->widget()); + CategoryWidget* categoryWidget = qobject_cast(activityLayout->itemAt(time)->widget()); categoryWidget->addFriendWidget(contact->getFriendWidget(), contact->getStatus()); } for (int i = 0; i < activityLayout->count(); ++i) { - CategoryWidget* categoryWidget = dynamic_cast(activityLayout->itemAt(i)->widget()); + CategoryWidget* categoryWidget = qobject_cast(activityLayout->itemAt(i)->widget()); categoryWidget->setVisible(categoryWidget->hasChatrooms()); } @@ -354,7 +354,7 @@ void FriendListWidget::removeFriendWidget(FriendWidget* w) { QDate activityDate = getDateFriend(contact); Time time = getTime(activityDate); - CategoryWidget* categoryWidget = dynamic_cast(activityLayout->itemAt(time)->widget()); + CategoryWidget* categoryWidget = qobject_cast(activityLayout->itemAt(time)->widget()); categoryWidget->removeFriendWidget(w, contact->getStatus()); categoryWidget->setVisible(categoryWidget->hasChatrooms()); } @@ -467,7 +467,7 @@ void FriendListWidget::cycleContacts(GenericChatroomWidget* activeChatroomWidget return; int index = -1; - FriendWidget* friendWidget = dynamic_cast(activeChatroomWidget); + FriendWidget* friendWidget = qobject_cast(activeChatroomWidget); if (mode == Activity) { @@ -476,7 +476,7 @@ void FriendListWidget::cycleContacts(GenericChatroomWidget* activeChatroomWidget QDate activityDate = getDateFriend(FriendList::findFriend(friendWidget->friendId)); index = getTime(activityDate); - CategoryWidget* categoryWidget = dynamic_cast(activityLayout->itemAt(index)->widget()); + CategoryWidget* categoryWidget = qobject_cast(activityLayout->itemAt(index)->widget()); if (categoryWidget == nullptr || categoryWidget->cycleContacts(friendWidget, forward)) return; @@ -497,7 +497,7 @@ void FriendListWidget::cycleContacts(GenericChatroomWidget* activeChatroomWidget continue; } - CategoryWidget* categoryWidget = dynamic_cast(activityLayout->itemAt(index)->widget()); + CategoryWidget* categoryWidget = qobject_cast(activityLayout->itemAt(index)->widget()); if (categoryWidget != nullptr) { @@ -542,7 +542,7 @@ void FriendListWidget::cycleContacts(GenericChatroomWidget* activeChatroomWidget } else { - GroupWidget* groupWidget = dynamic_cast(activeChatroomWidget); + GroupWidget* groupWidget = qobject_cast(activeChatroomWidget); if (groupWidget != nullptr) { currentLayout = groupLayout.getLayout(); @@ -575,7 +575,7 @@ void FriendListWidget::cycleContacts(GenericChatroomWidget* activeChatroomWidget // Go to the actual next index. if (currentLayout == listLayout->getLayoutOnline() || currentLayout == listLayout->getLayoutOffline() || currentLayout == groupLayout.getLayout()) { - GenericChatroomWidget* chatWidget = dynamic_cast(currentLayout->itemAt(index)->widget()); + GenericChatroomWidget* chatWidget = qobject_cast(currentLayout->itemAt(index)->widget()); if (chatWidget != nullptr) emit chatWidget->chatroomWidgetClicked(chatWidget); @@ -584,7 +584,7 @@ void FriendListWidget::cycleContacts(GenericChatroomWidget* activeChatroomWidget } else if (currentLayout == circleLayout->getLayout()) { - circleWidget = dynamic_cast(currentLayout->itemAt(index)->widget()); + circleWidget = qobject_cast(currentLayout->itemAt(index)->widget()); if (circleWidget != nullptr) { if (!circleWidget->cycleContacts(forward)) @@ -664,7 +664,7 @@ void FriendListWidget::moveWidget(FriendWidget* w, Status s, bool add) Friend* contact = FriendList::findFriend(w->friendId); QDate activityDate = getDateFriend(contact); Time time = getTime(activityDate); - CategoryWidget* categoryWidget = dynamic_cast(activityLayout->itemAt(time)->widget()); + CategoryWidget* categoryWidget = qobject_cast(activityLayout->itemAt(time)->widget()); categoryWidget->addFriendWidget(contact->getFriendWidget(), contact->getStatus()); categoryWidget->show(); } diff --git a/src/widget/friendwidget.cpp b/src/widget/friendwidget.cpp index e1c5df7ec..8e46eb649 100644 --- a/src/widget/friendwidget.cpp +++ b/src/widget/friendwidget.cpp @@ -110,9 +110,9 @@ void FriendWidget::contextMenuEvent(QContextMenuEvent * event) FriendListWidget *friendList; if (circleWidget == nullptr) - friendList = dynamic_cast(FriendList::findFriend(friendId)->getFriendWidget()->parentWidget()); + friendList = qobject_cast(FriendList::findFriend(friendId)->getFriendWidget()->parentWidget()); else - friendList = dynamic_cast(circleWidget->parentWidget()); + friendList = qobject_cast(circleWidget->parentWidget()); circleMenu = menu.addMenu(tr("Move to circle...", "Menu to move a friend into a different circle")); diff --git a/src/widget/genericchatitemlayout.cpp b/src/widget/genericchatitemlayout.cpp index 4f98850a3..8d1c2ddb8 100644 --- a/src/widget/genericchatitemlayout.cpp +++ b/src/widget/genericchatitemlayout.cpp @@ -49,7 +49,7 @@ int GenericChatItemLayout::indexOfSortedWidget(GenericChatItemWidget* widget) co if (index >= layout->count()) return -1; - GenericChatItemWidget* atMid = dynamic_cast(layout->itemAt(index)->widget()); + GenericChatItemWidget* atMid = qobject_cast(layout->itemAt(index)->widget()); assert(atMid != nullptr); if (atMid == widget) @@ -73,7 +73,7 @@ void GenericChatItemLayout::removeSortedWidget(GenericChatItemWidget* widget) if (layout->itemAt(index) == nullptr) return; - GenericChatItemWidget* atMid = dynamic_cast(layout->itemAt(index)->widget()); + GenericChatItemWidget* atMid = qobject_cast(layout->itemAt(index)->widget()); assert(atMid != nullptr); if (atMid == widget) @@ -84,7 +84,7 @@ void GenericChatItemLayout::search(const QString &searchString, bool hideAll) { for (int index = 0; index < layout->count(); ++index) { - GenericChatItemWidget* widgetAt = dynamic_cast(layout->itemAt(index)->widget()); + GenericChatItemWidget* widgetAt = qobject_cast(layout->itemAt(index)->widget()); assert(widgetAt != nullptr); widgetAt->searchName(searchString, hideAll); @@ -103,7 +103,7 @@ int GenericChatItemLayout::indexOfClosestSortedWidget(GenericChatItemWidget* wid while (min < max) { int mid = (max - min) / 2 + min; - GenericChatItemWidget* atMid = dynamic_cast(layout->itemAt(mid)->widget()); + GenericChatItemWidget* atMid = qobject_cast(layout->itemAt(mid)->widget()); assert(atMid != nullptr); bool lessThan = false;