diff --git a/src/audio/backend/alsink.h b/src/audio/backend/alsink.h index 031fca3b0..b742bba13 100644 --- a/src/audio/backend/alsink.h +++ b/src/audio/backend/alsink.h @@ -23,11 +23,12 @@ #include #include +#include "src/model/interface.h" #include "src/audio/iaudiosink.h" class OpenAL; class QMutex; -class AlSink : public IAudioSink +class AlSink : public QObject, public IAudioSink { Q_OBJECT public: @@ -38,16 +39,19 @@ public: AlSink& operator=(AlSink&& other) = delete; ~AlSink(); - void playAudioBuffer(const int16_t* data, int samples, unsigned channels, int sampleRate) const; - void playMono16Sound(const IAudioSink::Sound& sound); - void startLoop(); - void stopLoop(); + void playAudioBuffer(const int16_t* data, int samples, unsigned channels, int sampleRate) const override; + void playMono16Sound(const IAudioSink::Sound& sound) override; + void startLoop() override; + void stopLoop() override; - operator bool() const; + operator bool() const override; uint getSourceId() const; void kill(); + SIGNAL_IMPL(AlSink, finishedPlaying) + SIGNAL_IMPL(AlSink, invalidated) + private: OpenAL& audio; uint sourceId; diff --git a/src/audio/iaudiosink.h b/src/audio/iaudiosink.h index c5eeede43..acb5490d3 100644 --- a/src/audio/iaudiosink.h +++ b/src/audio/iaudiosink.h @@ -24,6 +24,8 @@ #include +#include "src/model/interface.h" + /** * @brief The IAudioSink class represents an interface to devices that can play audio. * @@ -65,9 +67,8 @@ * */ -class IAudioSink : public QObject +class IAudioSink { - Q_OBJECT public: enum class Sound { @@ -106,8 +107,8 @@ public: virtual operator bool() const = 0; signals: - void finishedPlaying(); - void invalidated(); + DECLARE_SIGNAL(finishedPlaying); + DECLARE_SIGNAL(invalidated); }; #endif // IAUDIOSINK_H diff --git a/src/core/toxcall.cpp b/src/core/toxcall.cpp index 2836c555b..e384d4d08 100644 --- a/src/core/toxcall.cpp +++ b/src/core/toxcall.cpp @@ -139,9 +139,7 @@ ToxFriendCall::ToxFriendCall(uint32_t FriendNum, bool VideoEnabled, CoreAV& av, qDebug() << "Audio input connection not working"; } - audioSinkInvalid = QObject::connect(sink.get(), &IAudioSink::invalidated, - [this]() { this->onAudioSinkInvalidated(); }); - + audioSinkInvalid = sink->connectTo_invalidated([this]() { this->onAudioSinkInvalidated(); }); // register video if (videoEnabled) { @@ -185,8 +183,7 @@ void ToxFriendCall::onAudioSinkInvalidated() { auto newSink = audio.makeSink(); - audioSinkInvalid = QObject::connect(newSink.get(), &IAudioSink::invalidated, - [this]() { this->onAudioSinkInvalidated(); }); + audioSinkInvalid = newSink->connectTo_invalidated([this]() { this->onAudioSinkInvalidated(); }); sink = std::move(newSink); } @@ -272,9 +269,7 @@ void ToxGroupCall::removePeer(ToxPk peerId) void ToxGroupCall::addPeer(ToxPk peerId) { std::unique_ptr newSink = audio.makeSink(); - QMetaObject::Connection con = - QObject::connect(newSink.get(), &IAudioSink::invalidated, - [this, peerId]() { this->onAudioSinkInvalidated(peerId); }); + QMetaObject::Connection con = newSink->connectTo_invalidated([this, peerId]() { this->onAudioSinkInvalidated(peerId); }); peers.emplace(peerId, std::move(newSink)); sinkInvalid.insert({peerId, con}); diff --git a/src/core/toxcall.h b/src/core/toxcall.h index 80a23d6e6..9d466c2d8 100644 --- a/src/core/toxcall.h +++ b/src/core/toxcall.h @@ -38,8 +38,10 @@ class AudioFilterer; class CoreVideoSource; class CoreAV; -class ToxCall +class ToxCall : public QObject { + Q_OBJECT + protected: ToxCall() = delete; ToxCall(bool VideoEnabled, CoreAV& av, IAudioControl& audio); diff --git a/src/model/about/aboutfriend.h b/src/model/about/aboutfriend.h index d6afd2aa4..665419f2c 100644 --- a/src/model/about/aboutfriend.h +++ b/src/model/about/aboutfriend.h @@ -21,7 +21,7 @@ #define ABOUT_FRIEND_H #include "iaboutfriend.h" - +#include "src/model/interface.h" #include "src/persistence/ifriendsettings.h" #include @@ -29,7 +29,7 @@ class Friend; class IFriendSettings; -class AboutFriend : public IAboutFriend +class AboutFriend : public QObject, public IAboutFriend { Q_OBJECT diff --git a/src/model/about/iaboutfriend.h b/src/model/about/iaboutfriend.h index 03499d9de..3769765ff 100644 --- a/src/model/about/iaboutfriend.h +++ b/src/model/about/iaboutfriend.h @@ -22,12 +22,11 @@ #include "src/model/interface.h" #include "src/persistence/ifriendsettings.h" + #include -class IAboutFriend : public QObject +class IAboutFriend { - Q_OBJECT - public: virtual QString getName() const = 0; virtual QString getStatusMessage() const = 0; diff --git a/src/model/profile/iprofileinfo.h b/src/model/profile/iprofileinfo.h index 88b2b3da0..a4ed93732 100644 --- a/src/model/profile/iprofileinfo.h +++ b/src/model/profile/iprofileinfo.h @@ -17,13 +17,14 @@ along with qTox. If not, see . */ +#include "src/model/interface.h" + #include class ToxId; -class IProfileInfo : public QObject +class IProfileInfo { - Q_OBJECT public: enum class RenameResult { OK, EmptyName, ProfileAlreadyExists, Error @@ -58,8 +59,7 @@ public: virtual SetAvatarResult setAvatar(const QString& path) = 0; virtual void removeAvatar() = 0; -signals: - void idChanged(const ToxId& id); - void usernameChanged(const QString& username); - void statusMessageChanged(const QString& message); + DECLARE_SIGNAL(idChanged, const ToxId&); + DECLARE_SIGNAL(usernameChanged, const QString&); + DECLARE_SIGNAL(statusMessageChanged, const QString&); }; diff --git a/src/model/profile/profileinfo.h b/src/model/profile/profileinfo.h index 3c637ed10..0cb55620d 100644 --- a/src/model/profile/profileinfo.h +++ b/src/model/profile/profileinfo.h @@ -17,6 +17,9 @@ along with qTox. If not, see . */ +#include +#include "src/model/interface.h" +#include "src/core/toxpk.h" #include "iprofileinfo.h" class Core; @@ -24,8 +27,9 @@ class QFile; class QPoint; class Profile; -class ProfileInfo : public IProfileInfo +class ProfileInfo : public QObject, public IProfileInfo { + Q_OBJECT public: ProfileInfo(Core* core, Profile* profile); @@ -50,6 +54,10 @@ public: SetAvatarResult setAvatar(const QString& path) override; void removeAvatar() override; + SIGNAL_IMPL(ProfileInfo, idChanged, const ToxId& id) + SIGNAL_IMPL(ProfileInfo, usernameChanged, const QString& name) + SIGNAL_IMPL(ProfileInfo, statusMessageChanged, const QString& message) + private: IProfileInfo::SetAvatarResult createAvatarFromFile(QFile& file, QByteArray& avatar); IProfileInfo::SetAvatarResult byteArrayToPng(QByteArray inData, QByteArray& outPng); diff --git a/src/util/strongtype.h b/src/util/strongtype.h index d83f854a6..7cb282e38 100644 --- a/src/util/strongtype.h +++ b/src/util/strongtype.h @@ -17,8 +17,8 @@ along with qTox. If not, see . */ -#ifndef STORNGTYPE_H -#define STORNGTYPE_H +#ifndef STRONGTYPE_H +#define STRONGTYPE_H #include @@ -129,4 +129,4 @@ uint qHash(const NamedType& key, uint seed = 0) { return qHash(key.get(), seed); } -#endif // STORNGTYPE_H +#endif // STRONGTYPE_H