From d9c3279c40ce28bf49a7ead0d185cf22fc92c294 Mon Sep 17 00:00:00 2001 From: Jimi Huotari Date: Mon, 16 Mar 2020 17:22:46 +0200 Subject: [PATCH] refactor(Qt): fix build with Qt 5.15 This fixes compile-time warnings about deprecated functions when building with Qt 5.15. (cherry picked from commit 6d51971c6fe6a7ee6beb5fa864b98c3231211279) --- src/core/core.cpp | 7 +++++++ src/main.cpp | 4 ++++ src/model/sessionchatlog.cpp | 4 ++++ src/persistence/history.cpp | 4 ++++ src/widget/emoticonswidget.cpp | 8 ++++++++ src/widget/flowlayout.cpp | 2 +- src/widget/form/loadhistorydialog.cpp | 4 ++++ src/widget/form/searchsettingsform.cpp | 4 ++++ src/widget/form/settings/privacyform.cpp | 11 +++++++++++ src/widget/genericchatitemlayout.h | 4 ++++ src/widget/tool/activatedialog.h | 4 ++++ 11 files changed, 55 insertions(+), 1 deletion(-) diff --git a/src/core/core.cpp b/src/core/core.cpp index 78c26a8a3..f19956ead 100644 --- a/src/core/core.cpp +++ b/src/core/core.cpp @@ -34,6 +34,9 @@ #include "src/util/strongtype.h" #include +#if (QT_VERSION >= QT_VERSION_CHECK(5, 15, 0)) +#include +#endif #include #include #include @@ -467,7 +470,11 @@ void Core::bootstrapDht() } int i = 0; +#if (QT_VERSION >= QT_VERSION_CHECK(5, 15, 0)) + static int j = QRandomGenerator::global()->generate() % listSize; +#else static int j = qrand() % listSize; +#endif // i think the more we bootstrap, the more we jitter because the more we overwrite nodes while (i < 2) { const DhtServer& dhtServer = bootstrapNodes[j % listSize]; diff --git a/src/main.cpp b/src/main.cpp index faacbaec3..b3966bb52 100644 --- a/src/main.cpp +++ b/src/main.cpp @@ -175,7 +175,9 @@ int main(int argc, char* argv[]) qInstallMessageHandler(logMessageHandler); // initialize random number generator +#if (QT_VERSION < QT_VERSION_CHECK(5, 15, 0)) qsrand(time(nullptr)); +#endif std::unique_ptr a(new QApplication(argc, argv)); @@ -207,7 +209,9 @@ int main(int argc, char* argv[]) osx::migrateProfiles(); #endif +#if (QT_VERSION < QT_VERSION_CHECK(5, 15, 0)) qsrand(time(nullptr)); +#endif Settings& settings = Settings::getInstance(); QString locale = settings.getTranslation(); Translator::translate(locale); diff --git a/src/model/sessionchatlog.cpp b/src/model/sessionchatlog.cpp index f4a224f0b..3019a5dcf 100644 --- a/src/model/sessionchatlog.cpp +++ b/src/model/sessionchatlog.cpp @@ -96,7 +96,11 @@ bool toxFileIsComplete(ToxFile::FileStatus status) std::map::const_iterator firstItemAfterDate(QDate date, const std::map& items) { +#if (QT_VERSION >= QT_VERSION_CHECK(5, 15, 0)) + return std::lower_bound(items.begin(), items.end(), QDateTime(date.startOfDay()), +#else return std::lower_bound(items.begin(), items.end(), QDateTime(date), +#endif [](const MessageDateAdaptor& a, MessageDateAdaptor const& b) { return a.timestamp.date() < b.timestamp.date(); }); diff --git a/src/persistence/history.cpp b/src/persistence/history.cpp index 6e9f29f6f..e3bbda856 100644 --- a/src/persistence/history.cpp +++ b/src/persistence/history.cpp @@ -957,7 +957,11 @@ QList History::getNumMessagesForFriendBeforeDateBoundaries(con "%4;") .arg(countMessagesForFriend) .arg(friendPkString) +#if (QT_VERSION >= QT_VERSION_CHECK(5, 15, 0)) + .arg(QDateTime(from.startOfDay()).toMSecsSinceEpoch()) +#else .arg(QDateTime(from).toMSecsSinceEpoch()) +#endif .arg(limitString); QList dateIdxs; diff --git a/src/widget/emoticonswidget.cpp b/src/widget/emoticonswidget.cpp index 3b29fa35b..180c72c2a 100644 --- a/src/widget/emoticonswidget.cpp +++ b/src/widget/emoticonswidget.cpp @@ -161,8 +161,16 @@ void EmoticonsWidget::mousePressEvent(QMouseEvent*) void EmoticonsWidget::wheelEvent(QWheelEvent* e) { +#if (QT_VERSION >= QT_VERSION_CHECK(5, 15, 0)) + const bool vertical = qAbs(e->angleDelta().y()) >= qAbs(e->angleDelta().x()); + const int delta = vertical ? e->angleDelta().y() : e->angleDelta().x(); + + if (vertical) { + if (delta < 0) { +#else if (e->orientation() == Qt::Vertical) { if (e->delta() < 0) { +#endif stack.setCurrentIndex(stack.currentIndex() + 1); } else { stack.setCurrentIndex(stack.currentIndex() - 1); diff --git a/src/widget/flowlayout.cpp b/src/widget/flowlayout.cpp index ac3895f04..b186664da 100644 --- a/src/widget/flowlayout.cpp +++ b/src/widget/flowlayout.cpp @@ -104,7 +104,7 @@ QLayoutItem* FlowLayout::takeAt(int index) Qt::Orientations FlowLayout::expandingDirections() const { - return nullptr; + return {}; } bool FlowLayout::hasHeightForWidth() const diff --git a/src/widget/form/loadhistorydialog.cpp b/src/widget/form/loadhistorydialog.cpp index 0e1925245..46241d7f9 100644 --- a/src/widget/form/loadhistorydialog.cpp +++ b/src/widget/form/loadhistorydialog.cpp @@ -52,7 +52,11 @@ LoadHistoryDialog::~LoadHistoryDialog() QDateTime LoadHistoryDialog::getFromDate() { +#if (QT_VERSION >= QT_VERSION_CHECK(5, 15, 0)) + QDateTime res(ui->fromDate->selectedDate().startOfDay()); +#else QDateTime res(ui->fromDate->selectedDate()); +#endif if (res.date().month() != ui->fromDate->monthShown() || res.date().year() != ui->fromDate->yearShown()) { QDate newDate(ui->fromDate->yearShown(), ui->fromDate->monthShown(), 1); diff --git a/src/widget/form/searchsettingsform.cpp b/src/widget/form/searchsettingsform.cpp index abdf6b40c..98014f8cf 100644 --- a/src/widget/form/searchsettingsform.cpp +++ b/src/widget/form/searchsettingsform.cpp @@ -37,7 +37,11 @@ SearchSettingsForm::SearchSettingsForm(QWidget *parent) : reloadTheme(); +#if (QT_VERSION >= QT_VERSION_CHECK(5, 15, 0)) + connect(ui->startSearchComboBox, QOverload::of(&QComboBox::currentIndexChanged), +#else connect(ui->startSearchComboBox, static_cast(&QComboBox::currentIndexChanged), +#endif this, &SearchSettingsForm::onStartSearchSelected); connect(ui->registerCheckBox, &QCheckBox::clicked, this, &SearchSettingsForm::onRegisterClicked); connect(ui->wordsOnlyRadioButton, &QCheckBox::clicked, this, &SearchSettingsForm::onWordsOnlyClicked); diff --git a/src/widget/form/settings/privacyform.cpp b/src/widget/form/settings/privacyform.cpp index 5d0ed9445..635e60f03 100644 --- a/src/widget/form/settings/privacyform.cpp +++ b/src/widget/form/settings/privacyform.cpp @@ -23,6 +23,9 @@ #include #include #include +#if (QT_VERSION >= QT_VERSION_CHECK(5, 15, 0)) +#include +#endif #include "src/core/core.h" #include "src/nexus.h" @@ -98,11 +101,19 @@ void PrivacyForm::showEvent(QShowEvent*) void PrivacyForm::on_randomNosapamButton_clicked() { QTime time = QTime::currentTime(); +#if (QT_VERSION >= QT_VERSION_CHECK(5, 15, 0)) + QRandomGenerator((uint)time.msec()); +#else qsrand((uint)time.msec()); +#endif uint32_t newNospam{0}; for (int i = 0; i < 4; ++i) +#if (QT_VERSION >= QT_VERSION_CHECK(5, 15, 0)) + newNospam = (newNospam << 8) + (QRandomGenerator::global()->generate() % 256); // Generate byte by byte. For some reason. +#else newNospam = (newNospam << 8) + (qrand() % 256); // Generate byte by byte. For some reason. +#endif Core::getInstance()->setNospam(newNospam); bodyUI->nospamLineEdit->setText(Core::getInstance()->getSelfId().getNoSpamString()); diff --git a/src/widget/genericchatitemlayout.h b/src/widget/genericchatitemlayout.h index aea161ec0..6d4bce7a3 100644 --- a/src/widget/genericchatitemlayout.h +++ b/src/widget/genericchatitemlayout.h @@ -33,7 +33,11 @@ public: GenericChatItemLayout(const GenericChatItemLayout& layout) = delete; ~GenericChatItemLayout(); +#if (QT_VERSION >= QT_VERSION_CHECK(5, 15, 0)) + void addSortedWidget(GenericChatItemWidget* widget, int stretch = 0, Qt::Alignment alignment = Qt::Alignment()); +#else void addSortedWidget(GenericChatItemWidget* widget, int stretch = 0, Qt::Alignment alignment = nullptr); +#endif int indexOfSortedWidget(GenericChatItemWidget* widget) const; bool existsSortedWidget(GenericChatItemWidget* widget) const; void removeSortedWidget(GenericChatItemWidget* widget); diff --git a/src/widget/tool/activatedialog.h b/src/widget/tool/activatedialog.h index c961841d1..422b68ace 100644 --- a/src/widget/tool/activatedialog.h +++ b/src/widget/tool/activatedialog.h @@ -26,7 +26,11 @@ class ActivateDialog : public QDialog { Q_OBJECT public: +#if (QT_VERSION >= QT_VERSION_CHECK(5, 15, 0)) + ActivateDialog(QWidget* parent = nullptr, Qt::WindowFlags f = Qt::WindowFlags()); +#else ActivateDialog(QWidget* parent = nullptr, Qt::WindowFlags f = nullptr); +#endif bool event(QEvent* event) override; signals: