From 2c0325770096e8644eedd514562043d2f8c54d16 Mon Sep 17 00:00:00 2001 From: bitok Date: Sun, 31 Jul 2016 17:17:11 +0300 Subject: [PATCH] refactor: fixes of static analyze warnings There is many static analyze warnings for qTox. Fixed most dangerous and several simple. --- src/nexus.cpp | 2 +- src/persistence/settingsserializer.h | 2 +- src/platform/camera/directshow.cpp | 4 ++-- src/widget/categorywidget.cpp | 8 ++++---- src/widget/contentdialog.cpp | 6 +++--- src/widget/form/chatform.cpp | 10 ++++++---- src/widget/form/chatform.h | 3 +++ src/widget/form/genericchatform.cpp | 4 ++-- src/widget/form/groupchatform.cpp | 9 +++++---- src/widget/friendlistlayout.cpp | 4 ++-- src/widget/friendlistwidget.cpp | 6 ++++-- src/widget/genericchatitemlayout.cpp | 2 +- src/widget/widget.cpp | 2 +- 13 files changed, 35 insertions(+), 27 deletions(-) diff --git a/src/nexus.cpp b/src/nexus.cpp index ca09439b3..a22d30cfb 100644 --- a/src/nexus.cpp +++ b/src/nexus.cpp @@ -351,7 +351,7 @@ void Nexus::updateWindowsArg(QWindow* closedWindow) windowMenu->addSeparator(); QAction* dockLast; - if (dockMenu->actions().count() != 0) + if (!dockMenu->actions().isEmpty()) dockLast = dockMenu->actions().first(); else dockLast = nullptr; diff --git a/src/persistence/settingsserializer.h b/src/persistence/settingsserializer.h index f0a201835..2f6d5a764 100644 --- a/src/persistence/settingsserializer.h +++ b/src/persistence/settingsserializer.h @@ -60,7 +60,7 @@ private: struct Value { - Value() : group{-2},array{-2},key{QString()},value{}{} + Value() : group{-2},array{-2},arrayIndex{-2},key{QString()},value{}{} Value(qint64 group, qint64 array, int arrayIndex, QString key, QVariant value) : group{group}, array{array}, arrayIndex{arrayIndex}, key{key}, value{value} {} qint64 group; diff --git a/src/platform/camera/directshow.cpp b/src/platform/camera/directshow.cpp index 38287464c..1e89c68ad 100644 --- a/src/platform/camera/directshow.cpp +++ b/src/platform/camera/directshow.cpp @@ -80,7 +80,7 @@ QVector> DirectShow::getDeviceList() devIdString = wcharToUtf8(olestr); // replace ':' with '_' since FFmpeg uses : to delimitate sources - for (unsigned i = 0; i < strlen(devIdString); i++) + for (size_t i = 0; i < strlen(devIdString); i++) if (devIdString[i] == ':') devIdString[i] = '_'; @@ -146,7 +146,7 @@ static IBaseFilter* getDevFilter(QString devName) devIdString = wcharToUtf8(olestr); // replace ':' with '_' since FFmpeg uses : to delimitate sources - for (unsigned i = 0; i < strlen(devIdString); i++) + for (size_t i = 0; i < strlen(devIdString); i++) if (devIdString[i] == ':') devIdString[i] = '_'; diff --git a/src/widget/categorywidget.cpp b/src/widget/categorywidget.cpp index 73ca47452..a93449c1b 100644 --- a/src/widget/categorywidget.cpp +++ b/src/widget/categorywidget.cpp @@ -163,13 +163,13 @@ bool CategoryWidget::cycleContacts(bool forward) } if (forward) { - if (listLayout->getLayoutOnline()->count() != 0) + if (!listLayout->getLayoutOnline()->isEmpty()) { setExpanded(true); emitChatroomWidget(listLayout->getLayoutOnline(), 0); return true; } - else if (listLayout->getLayoutOffline()->count() != 0) + else if (!listLayout->getLayoutOffline()->isEmpty()) { setExpanded(true); emitChatroomWidget(listLayout->getLayoutOffline(), 0); @@ -178,13 +178,13 @@ bool CategoryWidget::cycleContacts(bool forward) } else { - if (listLayout->getLayoutOffline()->count() != 0) + if (!listLayout->getLayoutOffline()->isEmpty()) { setExpanded(true); emitChatroomWidget(listLayout->getLayoutOffline(), listLayout->getLayoutOffline()->count() - 1); return true; } - else if (listLayout->getLayoutOnline()->count() != 0) + else if (!listLayout->getLayoutOnline()->isEmpty()) { setExpanded(true); emitChatroomWidget(listLayout->getLayoutOnline(), listLayout->getLayoutOnline()->count() - 1); diff --git a/src/widget/contentdialog.cpp b/src/widget/contentdialog.cpp index 2622dff47..b6bc9cbb0 100644 --- a/src/widget/contentdialog.cpp +++ b/src/widget/contentdialog.cpp @@ -328,9 +328,9 @@ void ContentDialog::cycleContacts(bool forward, bool loop) if (!loop && index == currentLayout->count() - 1) { bool groupsOnTop = Settings::getInstance().getGroupchatPosition(); - bool offlineEmpty = friendLayout->getLayoutOffline()->count() == 0; - bool onlineEmpty = offlineEmpty && ((friendLayout->getLayoutOnline()->count() == 0 && groupsOnTop) || !groupsOnTop); - bool groupsEmpty = offlineEmpty && ((groupLayout.getLayout()->count() == 0 && !groupsOnTop) || groupsOnTop); + bool offlineEmpty = friendLayout->getLayoutOffline()->isEmpty(); + bool onlineEmpty = offlineEmpty && (friendLayout->getLayoutOnline()->isEmpty() || !groupsOnTop); + bool groupsEmpty = offlineEmpty && (groupLayout.getLayout()->isEmpty() || groupsOnTop); if ((currentLayout == friendLayout->getLayoutOffline()) || (currentLayout == friendLayout->getLayoutOnline() && groupsEmpty) diff --git a/src/widget/form/chatform.cpp b/src/widget/form/chatform.cpp index f6ded4181..fea4f38c8 100644 --- a/src/widget/form/chatform.cpp +++ b/src/widget/form/chatform.cpp @@ -65,6 +65,8 @@ #include "src/nexus.h" #include "src/persistence/profile.h" +const QString ChatForm::ACTION_PREFIX = QStringLiteral("/me "); + ChatForm::ChatForm(Friend* chatFriend) : f(chatFriend) , isTyping(false) @@ -751,7 +753,7 @@ void ChatForm::loadHistory(QDateTime since, bool processUndelivered) // Show each messages ToxId authorId = ToxId(it.sender); QString authorStr = !it.dispName.isEmpty() ? it.dispName : (authorId.isSelf() ? Core::getInstance()->getUsername() : resolveToxId(authorId)); - bool isAction = it.message.startsWith("/me ", Qt::CaseInsensitive); + bool isAction = it.message.startsWith(ACTION_PREFIX, Qt::CaseInsensitive); bool needSending = !it.isSent && authorId.isSelf(); ChatMessage::Ptr msg = ChatMessage::createChatMessage(authorStr, @@ -972,9 +974,9 @@ void ChatForm::SendMessageStr(QString msg) if (msg.isEmpty()) return; - bool isAction = msg.startsWith("/me ", Qt::CaseInsensitive); + bool isAction = msg.startsWith(ACTION_PREFIX, Qt::CaseInsensitive); if (isAction) - msg = msg = msg.right(msg.length() - 4); + msg.remove(0, ACTION_PREFIX.length()); QList splittedMsg = Core::splitMessage(msg, TOX_MAX_MESSAGE_LENGTH); QDateTime timestamp = QDateTime::currentDateTime(); @@ -984,7 +986,7 @@ void ChatForm::SendMessageStr(QString msg) QString qt_msg = CString::toString(c_msg.data(), c_msg.size()); QString qt_msg_hist = qt_msg; if (isAction) - qt_msg_hist = "/me " + qt_msg; + qt_msg_hist = ACTION_PREFIX + qt_msg; bool status = !Settings::getInstance().getFauxOfflineMessaging(); diff --git a/src/widget/form/chatform.h b/src/widget/form/chatform.h index a7a5d99c7..7fff759ca 100644 --- a/src/widget/form/chatform.h +++ b/src/widget/form/chatform.h @@ -53,6 +53,8 @@ public: virtual void show(ContentLayout* contentLayout) final override; + static const QString ACTION_PREFIX; + signals: void sendFile(uint32_t friendId, QString, QString, long long); void aliasChanged(const QString& alias); @@ -108,6 +110,7 @@ protected: virtual void showEvent(QShowEvent* event) final override; private: + CoreAV* coreav; Friend* f; CroppingLabel *statusMessageLabel; diff --git a/src/widget/form/genericchatform.cpp b/src/widget/form/genericchatform.cpp index 678542b8c..6f360d6a7 100644 --- a/src/widget/form/genericchatform.cpp +++ b/src/widget/form/genericchatform.cpp @@ -412,12 +412,12 @@ void GenericChatForm::onSaveLogClicked() Timestamp* rightCol = dynamic_cast(l->getContent(2)); if (!rightCol) - return; + break; ChatLineContent* middleCol = l->getContent(1); ChatLineContent* leftCol = l->getContent(0); - QString timestamp = (!rightCol || rightCol->getTime().isNull()) ? tr("Not sent") : rightCol->getText(); + QString timestamp = rightCol->getTime().isNull() ? tr("Not sent") : rightCol->getText(); QString nick = leftCol->getText(); QString msg = middleCol->getText(); diff --git a/src/widget/form/groupchatform.cpp b/src/widget/form/groupchatform.cpp index fc3104de6..e51f5ce60 100644 --- a/src/widget/form/groupchatform.cpp +++ b/src/widget/form/groupchatform.cpp @@ -29,6 +29,7 @@ #include "src/widget/style.h" #include "src/widget/flowlayout.h" #include "src/widget/translator.h" +#include "src/widget/form/chatform.h" #include "src/video/groupnetcamview.h" #include #include @@ -153,9 +154,9 @@ void GroupChatForm::onSendTriggered() if (group->getPeersCount() != 1) { - if (msg.startsWith("/me ", Qt::CaseInsensitive)) + if (msg.startsWith(ChatForm::ACTION_PREFIX, Qt::CaseInsensitive)) { - msg = msg.right(msg.length() - 4); + msg.remove(0, ChatForm::ACTION_PREFIX.length()); emit sendAction(group->getGroupId(), msg); } else @@ -165,8 +166,8 @@ void GroupChatForm::onSendTriggered() } else { - if (msg.startsWith("/me ", Qt::CaseInsensitive)) - addSelfMessage(msg.right(msg.length() - 4), true, QDateTime::currentDateTime(), true); + if (msg.startsWith(ChatForm::ACTION_PREFIX, Qt::CaseInsensitive)) + addSelfMessage(msg.mid(ChatForm::ACTION_PREFIX.length()), true, QDateTime::currentDateTime(), true); else addSelfMessage(msg, false, QDateTime::currentDateTime(), true); } diff --git a/src/widget/friendlistlayout.cpp b/src/widget/friendlistlayout.cpp index 6901f7047..215296616 100644 --- a/src/widget/friendlistlayout.cpp +++ b/src/widget/friendlistlayout.cpp @@ -77,14 +77,14 @@ int FriendListLayout::indexOfFriendWidget(GenericChatItemWidget* widget, bool on void FriendListLayout::moveFriendWidgets(FriendListWidget* listWidget) { - while (friendOnlineLayout.getLayout()->count() != 0) + while (!friendOnlineLayout.getLayout()->isEmpty()) { QWidget* getWidget = friendOnlineLayout.getLayout()->takeAt(0)->widget(); FriendWidget* friendWidget = dynamic_cast(getWidget); listWidget->moveWidget(friendWidget, FriendList::findFriend(friendWidget->friendId)->getStatus(), true); } - while (friendOfflineLayout.getLayout()->count() != 0) + while (!friendOfflineLayout.getLayout()->isEmpty()) { QWidget* getWidget = friendOfflineLayout.getLayout()->takeAt(0)->widget(); diff --git a/src/widget/friendlistwidget.cpp b/src/widget/friendlistwidget.cpp index f8c8472e6..9e91e2f09 100644 --- a/src/widget/friendlistwidget.cpp +++ b/src/widget/friendlistwidget.cpp @@ -308,11 +308,11 @@ void FriendListWidget::setMode(Mode mode) listLayout->removeItem(listLayout->getLayoutOnline()); listLayout->removeItem(listLayout->getLayoutOffline()); - listLayout->removeItem(circleLayout->getLayout()); - listLayout->insertLayout(1, activityLayout); if (circleLayout != nullptr) { + listLayout->removeItem(circleLayout->getLayout()); + QLayoutItem* item; while ((item = circleLayout->getLayout()->takeAt(0)) != nullptr) { @@ -323,6 +323,8 @@ void FriendListWidget::setMode(Mode mode) circleLayout = nullptr; } + listLayout->insertLayout(1, activityLayout); + reDraw(); } } diff --git a/src/widget/genericchatitemlayout.cpp b/src/widget/genericchatitemlayout.cpp index 4f98850a3..d9de39fee 100644 --- a/src/widget/genericchatitemlayout.cpp +++ b/src/widget/genericchatitemlayout.cpp @@ -41,7 +41,7 @@ void GenericChatItemLayout::addSortedWidget(GenericChatItemWidget* widget, int s int GenericChatItemLayout::indexOfSortedWidget(GenericChatItemWidget* widget) const { - if (layout->count() == 0) + if (layout->isEmpty()) return -1; int index = indexOfClosestSortedWidget(widget); diff --git a/src/widget/widget.cpp b/src/widget/widget.cpp index a7d48852b..6979e38e1 100644 --- a/src/widget/widget.cpp +++ b/src/widget/widget.cpp @@ -1148,7 +1148,7 @@ void Widget::onFriendMessageReceived(int friendId, const QString& message, bool Profile* profile = Nexus::getProfile(); if (profile->isHistoryEnabled()) - profile->getHistory()->addNewMessage(f->getToxId().publicKey, isAction ? "/me " + f->getDisplayedName() + " " + message : message, + profile->getHistory()->addNewMessage(f->getToxId().publicKey, isAction ? ChatForm::ACTION_PREFIX + f->getDisplayedName() + " " + message : message, f->getToxId().publicKey, timestamp, true, f->getDisplayedName()); newFriendMessageAlert(friendId);