From 80f5de31b3b92fc5fc6fbe11380b0465de07ca2c Mon Sep 17 00:00:00 2001 From: Zetok Zalbavar Date: Sun, 26 Feb 2017 11:52:45 +0000 Subject: [PATCH] style: reformat current C++ codebase using clang-format --- src/audio/audio.cpp | 126 +-- src/audio/audio.h | 57 +- src/chatlog/chatline.cpp | 41 +- src/chatlog/chatline.h | 18 +- src/chatlog/chatlinecontent.cpp | 6 - src/chatlog/chatlinecontentproxy.cpp | 14 +- src/chatlog/chatlinecontentproxy.h | 7 +- src/chatlog/chatlog.cpp | 214 ++-- src/chatlog/chatlog.h | 16 +- src/chatlog/chatmessage.cpp | 138 +-- src/chatlog/chatmessage.h | 10 +- src/chatlog/content/filetransferwidget.cpp | 210 ++-- src/chatlog/content/filetransferwidget.h | 6 +- src/chatlog/content/image.h | 6 +- src/chatlog/content/notificationicon.cpp | 6 +- src/chatlog/content/notificationicon.h | 4 +- src/chatlog/content/spinner.cpp | 16 +- src/chatlog/content/spinner.h | 6 +- src/chatlog/content/text.cpp | 77 +- src/chatlog/content/text.h | 8 +- src/chatlog/content/timestamp.cpp | 2 +- src/chatlog/content/timestamp.h | 2 +- src/chatlog/customtextdocument.cpp | 12 +- src/chatlog/customtextdocument.h | 4 +- src/chatlog/documentcache.cpp | 7 +- src/chatlog/pixmapcache.cpp | 8 +- src/chatlog/pixmapcache.h | 6 +- src/chatlog/textformatter.cpp | 68 +- src/chatlog/textformatter.h | 1 - src/core/core.cpp | 610 +++++------ src/core/core.h | 63 +- src/core/coreav.cpp | 295 +++--- src/core/coreav.h | 36 +- src/core/corefile.cpp | 235 ++--- src/core/corefile.h | 76 +- src/core/corestructs.cpp | 34 +- src/core/corestructs.h | 15 +- src/core/cstring.cpp | 6 +- src/core/indexedlist.h | 20 +- src/core/recursivesignalblocker.cpp | 3 +- src/core/toxcall.cpp | 105 +- src/core/toxcall.h | 31 +- src/core/toxencrypt.cpp | 96 +- src/core/toxencrypt.h | 5 +- src/core/toxid.cpp | 69 +- src/core/toxid.h | 4 +- src/core/toxpk.cpp | 20 +- src/core/toxpk.h | 3 +- src/friend.cpp | 28 +- src/friend.h | 6 +- src/friendlist.cpp | 8 +- src/friendlist.h | 6 +- src/group.cpp | 34 +- src/group.h | 5 +- src/groupinvite.cpp | 16 +- src/groupinvite.h | 4 +- src/grouplist.cpp | 7 +- src/grouplist.h | 6 +- src/ipc.cpp | 124 +-- src/ipc.h | 11 +- src/main.cpp | 142 ++- src/net/autoupdate.cpp | 217 ++-- src/net/autoupdate.h | 12 +- src/net/avatarbroadcaster.cpp | 8 +- src/net/avatarbroadcaster.h | 2 +- src/net/toxme.cpp | 107 +- src/net/toxme.h | 17 +- src/net/toxuri.cpp | 75 +- src/net/toxuri.h | 4 +- src/nexus.cpp | 113 +- src/nexus.h | 4 +- src/persistence/db/rawdatabase.cpp | 242 ++--- src/persistence/db/rawdatabase.h | 33 +- src/persistence/history.cpp | 208 ++-- src/persistence/history.h | 37 +- src/persistence/offlinemsgengine.cpp | 32 +- src/persistence/offlinemsgengine.h | 16 +- src/persistence/profile.cpp | 260 ++--- src/persistence/profile.h | 5 +- src/persistence/profilelocker.cpp | 20 +- src/persistence/profilelocker.h | 2 +- src/persistence/serialize.cpp | 43 +- src/persistence/serialize.h | 2 +- src/persistence/settings.cpp | 504 ++++----- src/persistence/settings.h | 164 ++- src/persistence/settingsserializer.cpp | 216 ++-- src/persistence/settingsserializer.h | 49 +- src/persistence/smileypack.cpp | 80 +- src/persistence/smileypack.h | 4 +- src/persistence/toxsave.cpp | 5 +- src/platform/autorun.h | 7 +- src/platform/autorun_osx.cpp | 19 +- src/platform/autorun_win.cpp | 55 +- src/platform/autorun_xdg.cpp | 51 +- src/platform/camera/avfoundation.h | 13 +- src/platform/camera/directshow.cpp | 76 +- src/platform/camera/directshow.h | 11 +- src/platform/camera/v4l2.cpp | 65 +- src/platform/camera/v4l2.h | 16 +- src/platform/capslock.h | 5 +- src/platform/capslock_osx.cpp | 2 +- src/platform/capslock_win.cpp | 4 +- src/platform/capslock_x11.cpp | 9 +- src/platform/install_osx.cpp | 60 +- src/platform/install_osx.h | 12 +- src/platform/statusnotifier/closures.h | 12 +- src/platform/statusnotifier/enums.h | 16 +- src/platform/statusnotifier/interfaces.h | 12 +- src/platform/statusnotifier/statusnotifier.h | 172 ++- src/platform/timer.h | 5 +- src/platform/timer_osx.cpp | 7 +- src/platform/timer_win.cpp | 4 +- src/platform/timer_x11.cpp | 20 +- src/video/cameradevice.cpp | 163 ++- src/video/cameradevice.h | 12 +- src/video/camerasource.cpp | 112 +- src/video/camerasource.h | 16 +- src/video/corevideosource.cpp | 25 +- src/video/corevideosource.h | 10 +- src/video/genericnetcamview.cpp | 3 +- src/video/groupnetcamview.cpp | 55 +- src/video/groupnetcamview.h | 2 +- src/video/netcamview.cpp | 43 +- src/video/netcamview.h | 2 +- src/video/videoframe.cpp | 224 ++-- src/video/videoframe.h | 19 +- src/video/videomode.cpp | 35 +- src/video/videomode.h | 4 +- src/video/videosource.cpp | 2 +- src/video/videosource.h | 9 +- src/video/videosurface.cpp | 41 +- src/video/videosurface.h | 6 +- src/widget/about/aboutuser.cpp | 50 +- src/widget/about/aboutuser.h | 6 +- src/widget/categorywidget.cpp | 59 +- src/widget/categorywidget.h | 18 +- src/widget/circlewidget.cpp | 75 +- src/widget/circlewidget.h | 2 +- src/widget/contentdialog.cpp | 266 ++--- src/widget/contentdialog.h | 23 +- src/widget/contentlayout.cpp | 13 +- src/widget/emoticonswidget.cpp | 86 +- src/widget/emoticonswidget.h | 9 +- src/widget/flowlayout.cpp | 56 +- src/widget/flowlayout.h | 14 +- src/widget/form/addfriendform.cpp | 117 +- src/widget/form/addfriendform.h | 8 +- src/widget/form/chatform.cpp | 566 ++++------ src/widget/form/chatform.h | 22 +- src/widget/form/filesform.cpp | 14 +- src/widget/form/filesform.h | 8 +- src/widget/form/genericchatform.cpp | 172 ++- src/widget/form/genericchatform.h | 47 +- src/widget/form/groupchatform.cpp | 152 +-- src/widget/form/groupchatform.h | 6 +- src/widget/form/groupinviteform.cpp | 41 +- src/widget/form/groupinviteform.h | 5 +- src/widget/form/groupinvitewidget.cpp | 13 +- src/widget/form/loadhistorydialog.cpp | 10 +- src/widget/form/loadhistorydialog.h | 4 +- src/widget/form/profileform.cpp | 270 +++-- src/widget/form/profileform.h | 23 +- src/widget/form/setpassworddialog.cpp | 29 +- src/widget/form/setpassworddialog.h | 9 +- src/widget/form/settings/aboutform.cpp | 110 +- src/widget/form/settings/aboutform.h | 3 +- src/widget/form/settings/advancedform.cpp | 62 +- src/widget/form/settings/avform.cpp | 121 +-- src/widget/form/settings/avform.h | 17 +- src/widget/form/settings/generalform.cpp | 103 +- src/widget/form/settings/generalform.h | 6 +- src/widget/form/settings/genericsettings.cpp | 20 +- src/widget/form/settings/genericsettings.h | 8 +- src/widget/form/settings/privacyform.cpp | 17 +- .../form/settings/userinterfaceform.cpp | 48 +- src/widget/form/settings/userinterfaceform.h | 5 +- .../form/settings/verticalonlyscroller.cpp | 8 +- .../form/settings/verticalonlyscroller.h | 4 +- src/widget/form/settingswidget.cpp | 27 +- src/widget/form/settingswidget.h | 2 +- src/widget/form/tabcompleter.cpp | 53 +- src/widget/form/tabcompleter.h | 14 +- src/widget/friendlistlayout.cpp | 15 +- src/widget/friendlistlayout.h | 7 +- src/widget/friendlistwidget.cpp | 283 ++--- src/widget/friendlistwidget.h | 7 +- src/widget/friendwidget.cpp | 145 ++- src/widget/friendwidget.h | 6 +- src/widget/genericchatitemlayout.cpp | 23 +- src/widget/genericchatitemlayout.h | 3 +- src/widget/genericchatitemwidget.cpp | 7 +- src/widget/genericchatitemwidget.h | 2 +- src/widget/genericchatroomwidget.cpp | 48 +- src/widget/genericchatroomwidget.h | 18 +- src/widget/groupwidget.cpp | 66 +- src/widget/groupwidget.h | 2 +- src/widget/gui.cpp | 180 ++-- src/widget/gui.h | 40 +- src/widget/loginscreen.cpp | 99 +- src/widget/loginscreen.h | 6 +- src/widget/maskablepixmapwidget.cpp | 25 +- src/widget/maskablepixmapwidget.h | 6 +- src/widget/notificationedgewidget.cpp | 4 +- src/widget/notificationscrollarea.cpp | 94 +- src/widget/notificationscrollarea.h | 4 +- src/widget/passwordedit.cpp | 17 +- src/widget/passwordedit.h | 2 +- src/widget/qrwidget.cpp | 48 +- src/widget/splitterrestorer.cpp | 5 +- src/widget/style.cpp | 131 +-- src/widget/style.h | 2 +- src/widget/systemtrayicon.cpp | 248 ++--- src/widget/systemtrayicon.h | 10 +- src/widget/systemtrayicon_private.h | 20 +- src/widget/tool/activatedialog.cpp | 1 - src/widget/tool/adjustingscrollarea.cpp | 11 +- src/widget/tool/adjustingscrollarea.h | 2 +- src/widget/tool/callconfirmwidget.cpp | 61 +- src/widget/tool/callconfirmwidget.h | 8 +- src/widget/tool/chattextedit.cpp | 24 +- src/widget/tool/chattextedit.h | 4 +- src/widget/tool/croppinglabel.cpp | 25 +- src/widget/tool/croppinglabel.h | 4 +- src/widget/tool/flyoutoverlaywidget.cpp | 11 +- src/widget/tool/flyoutoverlaywidget.h | 4 +- src/widget/tool/friendrequestdialog.cpp | 26 +- src/widget/tool/friendrequestdialog.h | 8 +- src/widget/tool/micfeedbackwidget.cpp | 8 +- src/widget/tool/movablewidget.cpp | 66 +- src/widget/tool/movablewidget.h | 12 +- src/widget/tool/profileimporter.cpp | 42 +- src/widget/tool/profileimporter.h | 2 +- src/widget/tool/removefrienddialog.cpp | 2 +- src/widget/tool/removefrienddialog.h | 2 +- .../tool/screengrabberchooserrectitem.cpp | 70 +- .../tool/screengrabberchooserrectitem.h | 6 +- src/widget/tool/screengrabberoverlayitem.cpp | 10 +- src/widget/tool/screengrabberoverlayitem.h | 3 +- src/widget/tool/screenshotgrabber.cpp | 54 +- src/widget/tool/screenshotgrabber.h | 6 +- src/widget/tool/toolboxgraphicsitem.cpp | 4 +- src/widget/tool/toolboxgraphicsitem.h | 6 +- src/widget/translator.cpp | 47 +- src/widget/translator.h | 4 +- src/widget/widget.cpp | 995 +++++++----------- src/widget/widget.h | 60 +- test/chatlog/textformatter_test.cpp | 94 +- test/common.h | 6 +- test/core/toxid_test.cpp | 24 +- test/core/toxpk_test.cpp | 30 +- test/core/utils.h | 8 +- updater/main.cpp | 63 +- updater/serialize.cpp | 149 ++- updater/serialize.h | 2 +- updater/settings.cpp | 51 +- updater/update.cpp | 47 +- updater/update.h | 12 +- updater/widget.cpp | 80 +- updater/widget.h | 2 +- 259 files changed, 5914 insertions(+), 7772 deletions(-) mode change 100755 => 100644 updater/settings.cpp diff --git a/src/audio/audio.cpp b/src/audio/audio.cpp index d53f97a69..3287f8d42 100644 --- a/src/audio/audio.cpp +++ b/src/audio/audio.cpp @@ -27,8 +27,8 @@ #include #include #include -#include #include +#include #include @@ -56,8 +56,8 @@ public: static const ALchar* outDeviceNames() { return (alcIsExtensionPresent(NULL, "ALC_ENUMERATE_ALL_EXT") != AL_FALSE) - ? alcGetString(NULL, ALC_ALL_DEVICES_SPECIFIER) - : alcGetString(NULL, ALC_DEVICE_SPECIFIER); + ? alcGetString(NULL, ALC_ALL_DEVICES_SPECIFIER) + : alcGetString(NULL, ALC_DEVICE_SPECIFIER); } qreal inputGain() const @@ -77,12 +77,12 @@ public: } public: - qreal minInputGain; - qreal maxInputGain; + qreal minInputGain; + qreal maxInputGain; private: - qreal gain; - qreal gainFactor; + qreal gain; + qreal gainFactor; }; /** @@ -102,7 +102,8 @@ private: * @param s Name of the sound to get the path of. * @return The path of the requested sound. * - * @fn void Audio::frameAvailable(const int16_t *pcm, size_t sample_count, uint8_t channels, uint32_t sampling_rate); + * @fn void Audio::frameAvailable(const int16_t *pcm, size_t sample_count, uint8_t channels, + * uint32_t sampling_rate); * * When there are input subscribers, we regularly emit captured audio frames with this signal * Always connect with a blocking queued connection lambda, else the behaviour is undefined @@ -150,7 +151,7 @@ Audio::Audio() moveToThread(audioThread); connect(&captureTimer, &QTimer::timeout, this, &Audio::doCapture); - captureTimer.setInterval(AUDIO_FRAME_DURATION/2); + captureTimer.setInterval(AUDIO_FRAME_DURATION / 2); captureTimer.setSingleShot(false); captureTimer.start(); connect(&playMono16Timer, &QTimer::timeout, this, &Audio::playMono16SoundCleanup); @@ -175,7 +176,7 @@ void Audio::checkAlError() noexcept qWarning("OpenAL error: %d", al_err); } -void Audio::checkAlcError(ALCdevice *device) noexcept +void Audio::checkAlcError(ALCdevice* device) noexcept { const ALCenum alc_err = alcGetError(device); if (alc_err) @@ -191,8 +192,7 @@ qreal Audio::outputVolume() const ALfloat volume = 0.0; - if (alOutDev) - { + if (alOutDev) { alGetListenerf(AL_GAIN, &volume); checkAlError(); } @@ -302,8 +302,7 @@ void Audio::subscribeInput() { QMutexLocker locker(&audioLock); - if (!autoInitInput()) - { + if (!autoInitInput()) { qWarning("Failed to subscribe to audio input device."); return; } @@ -325,7 +324,8 @@ void Audio::unsubscribeInput() return; inSubscriptions--; - qDebug() << "Unsubscribed from audio input device [" << inSubscriptions << "subscriptions left ]"; + qDebug() << "Unsubscribed from audio input device [" << inSubscriptions + << "subscriptions left ]"; if (!inSubscriptions) cleanupInput(); @@ -367,14 +367,11 @@ bool Audio::initInput(const QString& deviceName) const ALCsizei bufSize = (frameDuration * sampleRate * 4) / 1000 * chnls; const QByteArray qDevName = deviceName.toUtf8(); - const ALchar* tmpDevName = qDevName.isEmpty() - ? nullptr - : qDevName.constData(); + const ALchar* tmpDevName = qDevName.isEmpty() ? nullptr : qDevName.constData(); alInDev = alcCaptureOpenDevice(tmpDevName, sampleRate, stereoFlag, bufSize); // Restart the capture if necessary - if (!alInDev) - { + if (!alInDev) { qWarning() << "Failed to initialize audio input device:" << deviceName; return false; } @@ -402,13 +399,10 @@ bool Audio::initOutput(const QString& deviceName) assert(!alOutDev); const QByteArray qDevName = deviceName.toUtf8(); - const ALchar* tmpDevName = qDevName.isEmpty() - ? nullptr - : qDevName.constData(); + const ALchar* tmpDevName = qDevName.isEmpty() ? nullptr : qDevName.constData(); alOutDev = alcOpenDevice(tmpDevName); - if (!alOutDev) - { + if (!alOutDev) { qWarning() << "Cannot open output audio device" << deviceName; return false; } @@ -417,8 +411,7 @@ bool Audio::initOutput(const QString& deviceName) alOutContext = alcCreateContext(alOutDev, nullptr); checkAlcError(alOutDev); - if (!alcMakeContextCurrent(alOutContext)) - { + if (!alcMakeContextCurrent(alOutContext)) { qWarning() << "Cannot create output audio context"; return false; } @@ -431,8 +424,7 @@ bool Audio::initOutput(const QString& deviceName) checkAlError(); Core* core = Core::getInstance(); - if (core) - { + if (core) { // reset each call's audio source core->getAv()->invalidateCallSources(); } @@ -466,8 +458,7 @@ void Audio::playMono16Sound(const QByteArray& data) ALint state; alGetSourcei(alMainSource, AL_SOURCE_STATE, &state); - if (state == AL_PLAYING) - { + if (state == AL_PLAYING) { alSourceStop(alMainSource); alSourcei(alMainSource, AL_BUFFER, AL_NONE); } @@ -480,7 +471,8 @@ void Audio::playMono16Sound(const QByteArray& data) playMono16Timer.start(durationMs + 50); } -void Audio::playAudioBuffer(ALuint alSource, const int16_t *data, int samples, unsigned channels, int sampleRate) +void Audio::playAudioBuffer(ALuint alSource, const int16_t* data, int samples, unsigned channels, + int sampleRate) { assert(channels == 1 || channels == 2); QMutexLocker locker(&audioLock); @@ -494,24 +486,19 @@ void Audio::playAudioBuffer(ALuint alSource, const int16_t *data, int samples, u alGetSourcei(alSource, AL_BUFFERS_QUEUED, &queued); alSourcei(alSource, AL_LOOPING, AL_FALSE); - if (processed) - { + if (processed) { ALuint bufids[processed]; alSourceUnqueueBuffers(alSource, processed, bufids); alDeleteBuffers(processed - 1, bufids + 1); bufid = bufids[0]; - } - else if (queued < 16) - { + } else if (queued < 16) { alGenBuffers(1, &bufid); - } - else - { + } else { return; } alBufferData(bufid, (channels == 1) ? AL_FORMAT_MONO16 : AL_FORMAT_STEREO16, data, - samples * 2 * channels, sampleRate); + samples * 2 * channels, sampleRate); alSourceQueueBuffers(alSource, 1, &bufid); ALint state; @@ -543,14 +530,12 @@ void Audio::cleanupOutput() { outputInitialized = false; - if (alOutDev) - { + if (alOutDev) { alSourcei(alMainSource, AL_LOOPING, AL_FALSE); alSourceStop(alMainSource); alDeleteSources(1, &alMainSource); - if (alMainBuffer) - { + if (alMainBuffer) { alDeleteBuffers(1, &alMainBuffer); alMainBuffer = 0; } @@ -578,8 +563,7 @@ void Audio::playMono16SoundCleanup() ALint state; alGetSourcei(alMainSource, AL_SOURCE_STATE, &state); - if (state == AL_STOPPED) - { + if (state == AL_STOPPED) { alSourcei(alMainSource, AL_BUFFER, AL_NONE); alDeleteBuffers(1, &alMainBuffer); alMainBuffer = 0; @@ -604,12 +588,11 @@ void Audio::doCapture() int16_t buf[AUDIO_FRAME_SAMPLE_COUNT * AUDIO_CHANNELS]; alcCaptureSamples(alInDev, buf, AUDIO_FRAME_SAMPLE_COUNT); - for (quint32 i = 0; i < AUDIO_FRAME_SAMPLE_COUNT * AUDIO_CHANNELS; ++i) - { + for (quint32 i = 0; i < AUDIO_FRAME_SAMPLE_COUNT * AUDIO_CHANNELS; ++i) { // gain amplification with clipping to 16-bit boundaries - int ampPCM = qBound(std::numeric_limits::min(), - qRound(buf[i] * d->inputGainFactor()), - std::numeric_limits::max()); + int ampPCM = + qBound(std::numeric_limits::min(), qRound(buf[i] * d->inputGainFactor()), + std::numeric_limits::max()); buf[i] = static_cast(ampPCM); } @@ -631,13 +614,11 @@ QStringList Audio::outDeviceNames() QStringList list; const ALchar* pDeviceList = Private::outDeviceNames(); - if (pDeviceList) - { - while (*pDeviceList) - { + if (pDeviceList) { + while (*pDeviceList) { int len = static_cast(strlen(pDeviceList)); list << QString::fromUtf8(pDeviceList, len); - pDeviceList += len+1; + pDeviceList += len + 1; } } @@ -649,13 +630,11 @@ QStringList Audio::inDeviceNames() QStringList list; const ALchar* pDeviceList = Private::inDeviceNames(); - if (pDeviceList) - { - while (*pDeviceList) - { + if (pDeviceList) { + while (*pDeviceList) { int len = static_cast(strlen(pDeviceList)); list << QString::fromUtf8(pDeviceList, len); - pDeviceList += len+1; + pDeviceList += len + 1; } } @@ -666,14 +645,12 @@ void Audio::subscribeOutput(ALuint& sid) { QMutexLocker locker(&audioLock); - if (!autoInitOutput()) - { + if (!autoInitOutput()) { qWarning("Failed to subscribe to audio output device."); return; } - if (!alcMakeContextCurrent(alOutContext)) - { + if (!alcMakeContextCurrent(alOutContext)) { qWarning("Failed to activate output context."); return; } @@ -682,23 +659,19 @@ void Audio::subscribeOutput(ALuint& sid) assert(sid); outSources << sid; - qDebug() << "Audio source" << sid << "created. Sources active:" - << outSources.size(); + qDebug() << "Audio source" << sid << "created. Sources active:" << outSources.size(); } -void Audio::unsubscribeOutput(ALuint &sid) +void Audio::unsubscribeOutput(ALuint& sid) { QMutexLocker locker(&audioLock); outSources.removeAll(sid); - if (sid) - { - if (alIsSource(sid)) - { + if (sid) { + if (alIsSource(sid)) { alDeleteSources(1, &sid); - qDebug() << "Audio source" << sid << "deleted. Sources active:" - << outSources.size(); + qDebug() << "Audio source" << sid << "deleted. Sources active:" << outSources.size(); } else { qWarning() << "Trying to delete invalid audio source" << sid; } @@ -724,8 +697,7 @@ void Audio::stopLoop() ALint state; alGetSourcei(alMainSource, AL_SOURCE_STATE, &state); - if (state == AL_STOPPED) - { + if (state == AL_STOPPED) { alSourcei(alMainSource, AL_BUFFER, AL_NONE); alDeleteBuffers(1, &alMainBuffer); alMainBuffer = 0; diff --git a/src/audio/audio.h b/src/audio/audio.h index 293f72e4e..dd9ab8b9e 100644 --- a/src/audio/audio.h +++ b/src/audio/audio.h @@ -24,18 +24,18 @@ #include #include -#include #include +#include #include #include #if defined(__APPLE__) && defined(__MACH__) - #include - #include +#include +#include #else - #include - #include +#include +#include #endif @@ -51,12 +51,16 @@ class Audio : public QObject class Private; public: + enum class Sound + { + NewMessage, + Test, + IncomingCall + }; - enum class Sound { NewMessage, Test, IncomingCall }; - - inline static QString getSound(Sound s) { - switch (s) - { + inline static QString getSound(Sound s) + { + switch (s) { case Sound::Test: return QStringLiteral(":/audio/notification.pcm"); case Sound::NewMessage: @@ -100,25 +104,26 @@ public: void playMono16Sound(const QByteArray& data); void playMono16Sound(const QString& path); - void playAudioBuffer(ALuint alSource, const int16_t *data, int samples, - unsigned channels, int sampleRate); + void playAudioBuffer(ALuint alSource, const int16_t* data, int samples, unsigned channels, + int sampleRate); public: // Public default audio settings static constexpr uint32_t AUDIO_SAMPLE_RATE = 48000; static constexpr uint32_t AUDIO_FRAME_DURATION = 20; - static constexpr ALint AUDIO_FRAME_SAMPLE_COUNT = AUDIO_FRAME_DURATION * AUDIO_SAMPLE_RATE/1000; + static constexpr ALint AUDIO_FRAME_SAMPLE_COUNT = AUDIO_FRAME_DURATION * AUDIO_SAMPLE_RATE / 1000; static constexpr uint32_t AUDIO_CHANNELS = 2; signals: - void frameAvailable(const int16_t *pcm, size_t sample_count, uint8_t channels, uint32_t sampling_rate); + void frameAvailable(const int16_t* pcm, size_t sample_count, uint8_t channels, + uint32_t sampling_rate); private: Audio(); ~Audio(); static void checkAlError() noexcept; - static void checkAlcError(ALCdevice *device) noexcept; + static void checkAlcError(ALCdevice* device) noexcept; bool autoInitInput(); bool autoInitOutput(); @@ -133,20 +138,20 @@ private: Private* d; private: - QThread* audioThread; - mutable QMutex audioLock; + QThread* audioThread; + mutable QMutex audioLock; - ALCdevice* alInDev; - quint32 inSubscriptions; - QTimer captureTimer, playMono16Timer; + ALCdevice* alInDev; + quint32 inSubscriptions; + QTimer captureTimer, playMono16Timer; - ALCdevice* alOutDev; - ALCcontext* alOutContext; - ALuint alMainSource; - ALuint alMainBuffer; - bool outputInitialized; + ALCdevice* alOutDev; + ALCcontext* alOutContext; + ALuint alMainSource; + ALuint alMainBuffer; + bool outputInitialized; - QList outSources; + QList outSources; }; #endif // AUDIO_H diff --git a/src/chatlog/chatline.cpp b/src/chatlog/chatline.cpp index 81cd905d5..f555f9f09 100644 --- a/src/chatlog/chatline.cpp +++ b/src/chatlog/chatline.cpp @@ -25,13 +25,11 @@ ChatLine::ChatLine() { - } ChatLine::~ChatLine() { - for (ChatLineContent* c : content) - { + for (ChatLineContent* c : content) { if (c->scene()) c->scene()->removeItem(c); @@ -49,8 +47,7 @@ void ChatLine::setRow(int idx) void ChatLine::visibilityChanged(bool visible) { - if (isVisible != visible) - { + if (isVisible != visible) { for (ChatLineContent* c : content) c->visibilityChanged(visible); } @@ -63,7 +60,7 @@ int ChatLine::getRow() const return row; } -ChatLineContent *ChatLine::getContent(int col) const +ChatLineContent* ChatLine::getContent(int col) const { if (col < static_cast(content.size()) && col >= 0) return content[col]; @@ -71,10 +68,9 @@ ChatLineContent *ChatLine::getContent(int col) const return nullptr; } -ChatLineContent *ChatLine::getContent(QPointF scenePos) const +ChatLineContent* ChatLine::getContent(QPointF scenePos) const { - for (ChatLineContent* c: content) - { + for (ChatLineContent* c : content) { if (c->sceneBoundingRect().contains(scenePos)) return c; } @@ -84,14 +80,13 @@ ChatLineContent *ChatLine::getContent(QPointF scenePos) const void ChatLine::removeFromScene() { - for (ChatLineContent* c : content) - { + for (ChatLineContent* c : content) { if (c->scene()) c->scene()->removeItem(c); } } -void ChatLine::addToScene(QGraphicsScene *scene) +void ChatLine::addToScene(QGraphicsScene* scene) { if (!scene) return; @@ -135,7 +130,8 @@ void ChatLine::updateBBox() bbox.setWidth(width); for (ChatLineContent* c : content) - bbox.setHeight(qMax(c->sceneBoundingRect().top() - bbox.top() + c->sceneBoundingRect().height(), bbox.height())); + bbox.setHeight(qMax(c->sceneBoundingRect().top() - bbox.top() + c->sceneBoundingRect().height(), + bbox.height())); } QRectF ChatLine::sceneBoundingRect() const @@ -152,10 +148,9 @@ void ChatLine::addColumn(ChatLineContent* item, ColumnFormat fmt) content.push_back(item); } -void ChatLine::replaceContent(int col, ChatLineContent *lineContent) +void ChatLine::replaceContent(int col, ChatLineContent* lineContent) { - if (col >= 0 && col < static_cast(content.size()) && lineContent) - { + if (col >= 0 && col < static_cast(content.size()) && lineContent) { QGraphicsScene* scene = content[col]->scene(); delete content[col]; @@ -179,11 +174,10 @@ void ChatLine::layout(qreal w, QPointF scenePos) width = w; bbox.setTopLeft(scenePos); - qreal fixedWidth = (content.size()-1) * columnSpacing; + qreal fixedWidth = (content.size() - 1) * columnSpacing; qreal varWidth = 0.0; // used for normalisation - for (int i = 0; i < format.size(); ++i) - { + for (int i = 0; i < format.size(); ++i) { if (format[i].policy == ColumnFormat::FixedSize) fixedWidth += format[i].size; else @@ -199,8 +193,7 @@ void ChatLine::layout(qreal w, QPointF scenePos) qreal xOffset = 0.0; QVector xPos(content.size()); - for (int i = 0; i < content.size(); ++i) - { + for (int i = 0; i < content.size(); ++i) { // calculate the effective width of the current column qreal width; if (format[i].policy == ColumnFormat::FixedSize) @@ -214,8 +207,7 @@ void ChatLine::layout(qreal w, QPointF scenePos) // calculate horizontal alignment qreal xAlign = 0.0; - switch(format[i].hAlign) - { + switch (format[i].hAlign) { case ColumnFormat::Left: break; case ColumnFormat::Right: @@ -233,8 +225,7 @@ void ChatLine::layout(qreal w, QPointF scenePos) maxVOffset = qMax(maxVOffset, content[i]->getAscent()); } - for (int i = 0; i < content.size(); ++i) - { + for (int i = 0; i < content.size(); ++i) { // calculate vertical alignment // vertical alignment may depend on width, so we do it in a second pass qreal yOffset = maxVOffset - content[i]->getAscent(); diff --git a/src/chatlog/chatline.h b/src/chatlog/chatline.h index f1d256438..24584bebd 100644 --- a/src/chatlog/chatline.h +++ b/src/chatlog/chatline.h @@ -20,10 +20,10 @@ #ifndef CHATLINE_H #define CHATLINE_H -#include #include #include #include +#include class ChatLog; class ChatLineContent; @@ -33,23 +33,28 @@ class QFont; struct ColumnFormat { - enum Policy { + enum Policy + { FixedSize, VariableSize, }; - enum Align { + enum Align + { Left, Center, Right, }; - ColumnFormat() {} + ColumnFormat() + { + } ColumnFormat(qreal s, Policy p, Align halign = Left) : size(s) , policy(p) , hAlign(halign) - {} + { + } qreal size = 1.0; Policy policy = VariableSize; @@ -86,7 +91,7 @@ public: bool isOverSelection(QPointF scenePos); - //comparators + // comparators static bool lessThanBSRectTop(const ChatLine::Ptr& lhs, const qreal& rhs); static bool lessThanBSRectBottom(const ChatLine::Ptr& lhs, const qreal& rhs); static bool lessThanRowIndex(const ChatLine::Ptr& lhs, const ChatLine::Ptr& rhs); @@ -109,7 +114,6 @@ private: qreal columnSpacing = 15.0; QRectF bbox; bool isVisible = false; - }; #endif // CHATLINE_H diff --git a/src/chatlog/chatlinecontent.cpp b/src/chatlog/chatlinecontent.cpp index 4f9f94332..938ebfb46 100644 --- a/src/chatlog/chatlinecontent.cpp +++ b/src/chatlog/chatlinecontent.cpp @@ -42,27 +42,22 @@ int ChatLineContent::type() const void ChatLineContent::selectionMouseMove(QPointF) { - } void ChatLineContent::selectionStarted(QPointF) { - } void ChatLineContent::selectionCleared() { - } void ChatLineContent::selectionDoubleClick(QPointF) { - } void ChatLineContent::selectionFocusChanged(bool) { - } bool ChatLineContent::isOverSelection(QPointF) const @@ -86,7 +81,6 @@ qreal ChatLineContent::getAscent() const void ChatLineContent::visibilityChanged(bool) { - } QString ChatLineContent::getText() const diff --git a/src/chatlog/chatlinecontentproxy.cpp b/src/chatlog/chatlinecontentproxy.cpp index a8ee6aad9..8f30ccb1d 100644 --- a/src/chatlog/chatlinecontentproxy.cpp +++ b/src/chatlog/chatlinecontentproxy.cpp @@ -19,10 +19,10 @@ #include "chatlinecontentproxy.h" #include "src/chatlog/content/filetransferwidget.h" -#include -#include -#include #include +#include +#include +#include /** * @enum ChatLineContentProxy::ChatLineContentProxyType @@ -32,7 +32,8 @@ * @value FileTransferWidgetType = 0 */ -ChatLineContentProxy::ChatLineContentProxy(QWidget* widget, ChatLineContentProxyType type, int minWidth, float widthInPercent) +ChatLineContentProxy::ChatLineContentProxy(QWidget* widget, ChatLineContentProxyType type, + int minWidth, float widthInPercent) : widthPercent(widthInPercent) , widthMin(minWidth) , widgetType{type} @@ -58,7 +59,8 @@ QRectF ChatLineContentProxy::boundingRect() const return result; } -void ChatLineContentProxy::paint(QPainter* painter, const QStyleOptionGraphicsItem* option, QWidget* widget) +void ChatLineContentProxy::paint(QPainter* painter, const QStyleOptionGraphicsItem* option, + QWidget* widget) { painter->setClipRect(boundingRect()); proxy->paint(painter, option, widget); @@ -76,7 +78,7 @@ QWidget* ChatLineContentProxy::getWidget() const void ChatLineContentProxy::setWidth(qreal width) { - proxy->widget()->setFixedWidth(qMax(static_cast(width*widthPercent), widthMin)); + proxy->widget()->setFixedWidth(qMax(static_cast(width * widthPercent), widthMin)); } ChatLineContentProxy::ChatLineContentProxyType ChatLineContentProxy::getWidgetType() const diff --git a/src/chatlog/chatlinecontentproxy.h b/src/chatlog/chatlinecontentproxy.h index 522d98cfd..f58ac60d5 100644 --- a/src/chatlog/chatlinecontentproxy.h +++ b/src/chatlog/chatlinecontentproxy.h @@ -20,8 +20,8 @@ #ifndef CHATLINECONTENTPROXY_H #define CHATLINECONTENTPROXY_H -#include #include "chatlinecontent.h" +#include class FileTransferWidget; @@ -33,7 +33,7 @@ public: enum ChatLineContentProxyType { GenericType, - FileTransferWidgetType=0, + FileTransferWidgetType = 0, }; public: @@ -49,7 +49,8 @@ public: ChatLineContentProxyType getWidgetType() const; protected: - ChatLineContentProxy(QWidget* widget, ChatLineContentProxyType type, int minWidth, float widthInPercent); + ChatLineContentProxy(QWidget* widget, ChatLineContentProxyType type, int minWidth, + float widthInPercent); private: QGraphicsProxyWidget* proxy; diff --git a/src/chatlog/chatlog.cpp b/src/chatlog/chatlog.cpp index f4ab801f3..b264c8a6b 100644 --- a/src/chatlog/chatlog.cpp +++ b/src/chatlog/chatlog.cpp @@ -18,27 +18,27 @@ */ #include "chatlog.h" -#include "chatmessage.h" #include "chatlinecontent.h" #include "chatlinecontentproxy.h" +#include "chatmessage.h" #include "content/filetransferwidget.h" #include "src/widget/translator.h" -#include -#include +#include #include #include -#include -#include +#include #include +#include #include +#include /** * @var ChatLog::repNameAfter * @brief repetition interval sender name (sec) */ -template +template T clamp(T x, T min, T max) { if (x > max) @@ -68,7 +68,7 @@ ChatLog::ChatLog(QWidget* parent) setBackgroundBrush(QBrush(Qt::white, Qt::SolidPattern)); // The selection rect for multi-line selection - selGraphItem = scene->addRect(0,0,0,0,selectionRectColor.darker(120),selectionRectColor); + selGraphItem = scene->addRect(0, 0, 0, 0, selectionRectColor.darker(120), selectionRectColor); selGraphItem->setZValue(-1.0); // behind all other items // copy action (ie. Ctrl+C) @@ -76,33 +76,24 @@ ChatLog::ChatLog(QWidget* parent) copyAction->setIcon(QIcon::fromTheme("edit-copy")); copyAction->setShortcut(QKeySequence::Copy); copyAction->setEnabled(false); - connect(copyAction, &QAction::triggered, this, [this]() - { - copySelectedText(); - }); + connect(copyAction, &QAction::triggered, this, [this]() { copySelectedText(); }); addAction(copyAction); // Ctrl+Insert shortcut QShortcut* copyCtrlInsShortcut = new QShortcut(QKeySequence(Qt::CTRL + Qt::Key_Insert), this); - connect(copyCtrlInsShortcut, &QShortcut::activated, this, [this]() - { - copySelectedText(); - }); + connect(copyCtrlInsShortcut, &QShortcut::activated, this, [this]() { copySelectedText(); }); // select all action (ie. Ctrl+A) selectAllAction = new QAction(this); selectAllAction->setIcon(QIcon::fromTheme("edit-select-all")); selectAllAction->setShortcut(QKeySequence::SelectAll); - connect(selectAllAction, &QAction::triggered, this, [this]() - { - selectAll(); - }); + connect(selectAllAction, &QAction::triggered, this, [this]() { selectAll(); }); addAction(selectAllAction); // This timer is used to scroll the view while the user is // moving the mouse past the top/bottom edge of the widget while selecting. selectionTimer = new QTimer(this); - selectionTimer->setInterval(1000/30); + selectionTimer->setInterval(1000 / 30); selectionTimer->setSingleShot(false); selectionTimer->start(); connect(selectionTimer, &QTimer::timeout, this, &ChatLog::onSelectionTimerTimeout); @@ -144,7 +135,7 @@ void ChatLog::clearSelection() if (selectionMode == None) return; - for (int i=selFirstRow; i<=selLastRow; ++i) + for (int i = selFirstRow; i <= selLastRow; ++i) lines[i]->selectionCleared(); selFirstRow = -1; @@ -183,8 +174,7 @@ void ChatLog::layout(int start, int end, qreal width) start = clamp(start, 0, lines.size()); end = clamp(end + 1, 0, lines.size()); - for (int i = start; i < end; ++i) - { + for (int i = start; i < end; ++i) { ChatLine* l = lines[i].get(); l->layout(width, QPointF(0.0, h)); @@ -196,8 +186,7 @@ void ChatLog::mousePressEvent(QMouseEvent* ev) { QGraphicsView::mousePressEvent(ev); - if (ev->button() == Qt::LeftButton) - { + if (ev->button() == Qt::LeftButton) { clickPos = ev->pos(); clearSelection(); } @@ -216,9 +205,8 @@ void ChatLog::mouseMoveEvent(QMouseEvent* ev) QPointF scenePos = mapToScene(ev->pos()); - if (ev->buttons() & Qt::LeftButton) - { - //autoscroll + if (ev->buttons() & Qt::LeftButton) { + // autoscroll if (ev->pos().y() < 0) selectionScrollDir = Up; else if (ev->pos().y() > height()) @@ -226,15 +214,14 @@ void ChatLog::mouseMoveEvent(QMouseEvent* ev) else selectionScrollDir = NoDirection; - //select - if (selectionMode == None && (clickPos - ev->pos()).manhattanLength() > QApplication::startDragDistance()) - { + // select + if (selectionMode == None + && (clickPos - ev->pos()).manhattanLength() > QApplication::startDragDistance()) { QPointF sceneClickPos = mapToScene(clickPos.toPoint()); ChatLine::Ptr line = findLineByPosY(scenePos.y()); ChatLineContent* content = getContentFromPos(sceneClickPos); - if (content) - { + if (content) { selClickedRow = content->getRow(); selClickedCol = content->getColumn(); selFirstRow = content->getRow(); @@ -247,9 +234,7 @@ void ChatLog::mouseMoveEvent(QMouseEvent* ev) // ungrab mouse grabber if (scene->mouseGrabberItem()) scene->mouseGrabberItem()->ungrabMouse(); - } - else if (line.get()) - { + } else if (line.get()) { selClickedRow = line->getRow(); selFirstRow = selClickedRow; selLastRow = selClickedRow; @@ -258,44 +243,34 @@ void ChatLog::mouseMoveEvent(QMouseEvent* ev) } } - if (selectionMode != None) - { + if (selectionMode != None) { ChatLineContent* content = getContentFromPos(scenePos); ChatLine::Ptr line = findLineByPosY(scenePos.y()); int row; - if (content) - { + if (content) { row = content->getRow(); int col = content->getColumn(); - if (row == selClickedRow && col == selClickedCol) - { + if (row == selClickedRow && col == selClickedCol) { selectionMode = Precise; content->selectionMouseMove(scenePos); selGraphItem->hide(); - } - else if (col != selClickedCol) - { + } else if (col != selClickedCol) { selectionMode = Multi; lines[selClickedRow]->selectionCleared(); } - } - else if (line.get()) - { + } else if (line.get()) { row = line->getRow(); - if (row != selClickedRow) - { + if (row != selClickedRow) { selectionMode = Multi; lines[selClickedRow]->selectionCleared(); } - } - else - { + } else { return; } @@ -312,15 +287,16 @@ void ChatLog::mouseMoveEvent(QMouseEvent* ev) } } -//Much faster than QGraphicsScene::itemAt()! +// Much faster than QGraphicsScene::itemAt()! ChatLineContent* ChatLog::getContentFromPos(QPointF scenePos) const { if (lines.empty()) return nullptr; - auto itr = std::lower_bound(lines.cbegin(), lines.cend(), scenePos.y(), ChatLine::lessThanBSRectBottom); + auto itr = + std::lower_bound(lines.cbegin(), lines.cend(), scenePos.y(), ChatLine::lessThanBSRectBottom); - //find content + // find content if (itr != lines.cend() && (*itr)->sceneBoundingRect().contains(scenePos)) return (*itr)->getContent(scenePos); @@ -329,15 +305,12 @@ ChatLineContent* ChatLog::getContentFromPos(QPointF scenePos) const bool ChatLog::isOverSelection(QPointF scenePos) const { - if (selectionMode == Precise) - { + if (selectionMode == Precise) { ChatLineContent* content = getContentFromPos(scenePos); if (content) return content->isOverSelection(scenePos); - } - else if (selectionMode == Multi) - { + } else if (selectionMode == Multi) { if (selGraphItem->rect().contains(scenePos)) return true; } @@ -358,8 +331,7 @@ void ChatLog::reposition(int start, int end, qreal deltaY) start = clamp(start, 0, lines.size() - 1); end = clamp(end + 1, 0, lines.size()); - for (int i = start; i < end; ++i) - { + for (int i = start; i < end; ++i) { ChatLine* l = lines[i].get(); l->moveBy(deltaY); } @@ -372,12 +344,12 @@ void ChatLog::insertChatlineAtBottom(ChatLine::Ptr l) bool stickToBtm = stickToBottom(); - //insert + // insert l->setRow(lines.size()); l->addToScene(scene); lines.append(l); - //partial refresh + // partial refresh layout(lines.last()->getRow(), lines.size(), useableWidth()); updateSceneRect(); @@ -410,8 +382,7 @@ void ChatLog::insertChatlineOnTop(const QList& newLines) // add the new lines int i = 0; - for (ChatLine::Ptr l : newLines) - { + for (ChatLine::Ptr l : newLines) { l->addToScene(scene); l->visibilityChanged(false); l->setRow(i++); @@ -419,8 +390,7 @@ void ChatLog::insertChatlineOnTop(const QList& newLines) } // add the old lines - for (ChatLine::Ptr l : lines) - { + for (ChatLine::Ptr l : lines) { l->setRow(i++); combLines.push_back(l); } @@ -450,8 +420,7 @@ void ChatLog::startResizeWorker() return; // (re)start the worker - if (!workerTimer->isActive()) - { + if (!workerTimer->isActive()) { // these values must not be reevaluated while the worker is running workerStb = stickToBottom(); @@ -462,8 +431,7 @@ void ChatLog::startResizeWorker() // switch to busy scene displaying the busy notification if there is a lot // of text to be resized int txt = 0; - for (ChatLine::Ptr line : lines) - { + for (ChatLine::Ptr line : lines) { if (txt > 500000) break; for (ChatLineContent* content : line->content) @@ -478,13 +446,12 @@ void ChatLog::startResizeWorker() verticalScrollBar()->hide(); } -void ChatLog::mouseDoubleClickEvent(QMouseEvent *ev) +void ChatLog::mouseDoubleClickEvent(QMouseEvent* ev) { QPointF scenePos = mapToScene(ev->pos()); ChatLineContent* content = getContentFromPos(scenePos); - if (content) - { + if (content) { content->selectionDoubleClick(scenePos); selClickedCol = content->getColumn(); selClickedRow = content->getRow(); @@ -498,25 +465,24 @@ void ChatLog::mouseDoubleClickEvent(QMouseEvent *ev) QString ChatLog::getSelectedText() const { - if (selectionMode == Precise) - { + if (selectionMode == Precise) { return lines[selClickedRow]->content[selClickedCol]->getSelectedText(); - } - else if (selectionMode == Multi) - { + } else if (selectionMode == Multi) { // build a nicely formatted message QString out; - for (int i=selFirstRow; i<=selLastRow; ++i) - { + for (int i = selFirstRow; i <= selLastRow; ++i) { if (lines[i]->content[1]->getText().isEmpty()) continue; - QString timestamp = lines[i]->content[2]->getText().isEmpty() ? tr("pending") : lines[i]->content[2]->getText(); + QString timestamp = lines[i]->content[2]->getText().isEmpty() + ? tr("pending") + : lines[i]->content[2]->getText(); QString author = lines[i]->content[0]->getText(); QString msg = lines[i]->content[1]->getText(); - out += QString(out.isEmpty() ? "[%2] %1: %3" : "\n[%2] %1: %3").arg(author, timestamp, msg); + out += + QString(out.isEmpty() ? "[%2] %1: %3" : "\n[%2] %1: %3").arg(author, timestamp, msg); } return out; @@ -547,8 +513,7 @@ QVector ChatLog::getLines() ChatLine::Ptr ChatLog::getLatestLine() const { - if (!lines.empty()) - { + if (!lines.empty()) { return lines.last(); } return nullptr; @@ -559,7 +524,7 @@ ChatLine::Ptr ChatLog::getLatestLine() const * @param pos Position on screen in global coordinates * @sa getContentFromPos() */ -ChatLineContent *ChatLog::getContentFromGlobalPos(QPoint pos) const +ChatLineContent* ChatLog::getContentFromGlobalPos(QPoint pos) const { return getContentFromPos(mapToScene(mapFromGlobal(pos))); } @@ -570,8 +535,7 @@ void ChatLog::clear() QVector savedLines; - for (ChatLine::Ptr l : lines) - { + for (ChatLine::Ptr l : lines) { if (isActiveFileTransfer(l)) savedLines.push_back(l); else @@ -616,8 +580,7 @@ void ChatLog::setTypingNotification(ChatLine::Ptr notification) void ChatLog::setTypingNotificationVisible(bool visible) { - if (typingNotification.get()) - { + if (typingNotification.get()) { typingNotification->setVisible(visible); updateTypingNotification(); } @@ -641,7 +604,7 @@ void ChatLog::selectAll() selectionMode = Multi; selFirstRow = 0; - selLastRow = lines.size()-1; + selLastRow = lines.size() - 1; emit selectionChanged(); updateMultiSelectionRect(); @@ -649,8 +612,7 @@ void ChatLog::selectAll() void ChatLog::fontChanged(const QFont& font) { - for (ChatLine::Ptr l : lines) - { + for (ChatLine::Ptr l : lines) { l->fontChanged(font); } } @@ -666,15 +628,16 @@ void ChatLog::checkVisibility() return; // find first visible line - auto lowerBound = std::lower_bound(lines.cbegin(), lines.cend(), getVisibleRect().top(), ChatLine::lessThanBSRectBottom); + auto lowerBound = std::lower_bound(lines.cbegin(), lines.cend(), getVisibleRect().top(), + ChatLine::lessThanBSRectBottom); // find last visible line - auto upperBound = std::lower_bound(lowerBound, lines.cend(), getVisibleRect().bottom(), ChatLine::lessThanBSRectTop); + auto upperBound = std::lower_bound(lowerBound, lines.cend(), getVisibleRect().bottom(), + ChatLine::lessThanBSRectTop); // set visibilty QList newVisibleLines; - for (auto itr = lowerBound; itr != upperBound; ++itr) - { + for (auto itr = lowerBound; itr != upperBound; ++itr) { newVisibleLines.append(*itr); if (!visibleLines.contains(*itr)) @@ -692,8 +655,9 @@ void ChatLog::checkVisibility() // enforce order std::sort(visibleLines.begin(), visibleLines.end(), ChatLine::lessThanRowIndex); - //if (!visibleLines.empty()) - // qDebug() << "visible from " << visibleLines.first()->getRow() << "to " << visibleLines.last()->getRow() << " total " << visibleLines.size(); + // if (!visibleLines.empty()) + // qDebug() << "visible from " << visibleLines.first()->getRow() << "to " << + // visibleLines.last()->getRow() << " total " << visibleLines.size(); } void ChatLog::scrollContentsBy(int dx, int dy) @@ -706,8 +670,7 @@ void ChatLog::resizeEvent(QResizeEvent* ev) { bool stb = stickToBottom(); - if (ev->size().width() != ev->oldSize().width()) - { + if (ev->size().width() != ev->oldSize().width()) { startResizeWorker(); stb = false; // let the resize worker handle it } @@ -722,8 +685,7 @@ void ChatLog::resizeEvent(QResizeEvent* ev) void ChatLog::updateMultiSelectionRect() { - if (selectionMode == Multi && selFirstRow >= 0 && selLastRow >= 0) - { + if (selectionMode == Multi && selFirstRow >= 0 && selLastRow >= 0) { QRectF selBBox; selBBox = selBBox.united(lines[selFirstRow]->sceneBoundingRect()); selBBox = selBBox.united(lines[selLastRow]->sceneBoundingRect()); @@ -733,9 +695,7 @@ void ChatLog::updateMultiSelectionRect() selGraphItem->setRect(selBBox); selGraphItem->show(); - } - else - { + } else { selGraphItem->hide(); } } @@ -756,10 +716,10 @@ void ChatLog::updateTypingNotification() void ChatLog::updateBusyNotification() { - if (busyNotification.get()) - { - //repoisition the busy notification (centered) - busyNotification->layout(useableWidth(), getVisibleRect().topLeft() + QPointF(0, getVisibleRect().height()/2.0)); + if (busyNotification.get()) { + // repoisition the busy notification (centered) + busyNotification->layout(useableWidth(), getVisibleRect().topLeft() + + QPointF(0, getVisibleRect().height() / 2.0)); } } @@ -780,15 +740,15 @@ QRectF ChatLog::calculateSceneRect() const if (typingNotification.get() != nullptr) bottom += typingNotification->sceneBoundingRect().height() + lineSpacing; - return QRectF(-margins.left(), -margins.top(), useableWidth(), bottom + margins.bottom() + margins.top()); + return QRectF(-margins.left(), -margins.top(), useableWidth(), + bottom + margins.bottom() + margins.top()); } void ChatLog::onSelectionTimerTimeout() { const int scrollSpeed = 10; - switch(selectionScrollDir) - { + switch (selectionScrollDir) { case Up: verticalScrollBar()->setValue(verticalScrollBar()->value() - scrollSpeed); break; @@ -806,12 +766,11 @@ void ChatLog::onWorkerTimeout() // large values will make the UI unresponsive const int stepSize = 50; - layout(workerLastIndex, workerLastIndex+stepSize, useableWidth()); + layout(workerLastIndex, workerLastIndex + stepSize, useableWidth()); workerLastIndex += stepSize; // done? - if (workerLastIndex >= lines.size()) - { + if (workerLastIndex >= lines.size()) { workerTimer->stop(); // switch back to the scene containing the chat messages @@ -848,11 +807,10 @@ void ChatLog::focusInEvent(QFocusEvent* ev) { QGraphicsView::focusInEvent(ev); - if (selectionMode != None) - { + if (selectionMode != None) { selGraphItem->setBrush(QBrush(selectionRectColor)); - for (int i=selFirstRow; i<=selLastRow; ++i) + for (int i = selFirstRow; i <= selLastRow; ++i) lines[i]->selectionFocusChanged(true); } } @@ -861,11 +819,10 @@ void ChatLog::focusOutEvent(QFocusEvent* ev) { QGraphicsView::focusOutEvent(ev); - if (selectionMode != None) - { + if (selectionMode != None) { selGraphItem->setBrush(QBrush(selectionRectColor.lighter(120))); - for (int i=selFirstRow; i<=selLastRow; ++i) + for (int i = selFirstRow; i <= selLastRow; ++i) lines[i]->selectionFocusChanged(false); } } @@ -879,15 +836,14 @@ void ChatLog::retranslateUi() bool ChatLog::isActiveFileTransfer(ChatLine::Ptr l) { int count = l->getColumnCount(); - for (int i = 0; i < count; ++i) - { - ChatLineContent *content = l->getContent(i); - ChatLineContentProxy *proxy = qobject_cast(content); + for (int i = 0; i < count; ++i) { + ChatLineContent* content = l->getContent(i); + ChatLineContentProxy* proxy = qobject_cast(content); if (!proxy) continue; QWidget* widget = proxy->getWidget(); - FileTransferWidget *transferWidget = qobject_cast(widget); + FileTransferWidget* transferWidget = qobject_cast(widget); if (transferWidget && transferWidget->isActive()) return true; } diff --git a/src/chatlog/chatlog.h b/src/chatlog/chatlog.h index 1365a0398..af3b7cf1a 100644 --- a/src/chatlog/chatlog.h +++ b/src/chatlog/chatlog.h @@ -20,8 +20,8 @@ #ifndef CHATLOG_H #define CHATLOG_H -#include #include +#include #include #include "chatline.h" @@ -63,7 +63,7 @@ public: QVector getLines(); ChatLine::Ptr getLatestLine() const; ChatLineContent* getContentFromGlobalPos(QPoint pos) const; - const uint repNameAfter = 5*60; + const uint repNameAfter = 5 * 60; signals: void selectionChanged(); @@ -113,13 +113,15 @@ private: bool isActiveFileTransfer(ChatLine::Ptr l); private: - enum SelectionMode { + enum SelectionMode + { None, Precise, Multi, }; - enum AutoScrollDirection { + enum AutoScrollDirection + { NoDirection, Up, Down, @@ -135,7 +137,7 @@ private: ChatLine::Ptr busyNotification; // selection - int selClickedRow = -1; //These 4 are only valid while selectionMode != None + int selClickedRow = -1; // These 4 are only valid while selectionMode != None int selClickedCol = -1; int selFirstRow = -1; int selLastRow = -1; @@ -147,13 +149,13 @@ private: QTimer* workerTimer = nullptr; AutoScrollDirection selectionScrollDir = NoDirection; - //worker vars + // worker vars int workerLastIndex = 0; bool workerStb = false; ChatLine::Ptr workerAnchorLine; // layout - QMargins margins = QMargins(10,10,10,10); + QMargins margins = QMargins(10, 10, 10, 10); qreal lineSpacing = 5.0f; }; diff --git a/src/chatlog/chatmessage.cpp b/src/chatlog/chatmessage.cpp index fc37130cb..335bcdc13 100644 --- a/src/chatlog/chatmessage.cpp +++ b/src/chatlog/chatmessage.cpp @@ -20,12 +20,12 @@ #include "chatmessage.h" #include "chatlinecontentproxy.h" #include "textformatter.h" -#include "content/text.h" -#include "content/timestamp.h" -#include "content/spinner.h" #include "content/filetransferwidget.h" #include "content/image.h" #include "content/notificationicon.h" +#include "content/spinner.h" +#include "content/text.h" +#include "content/timestamp.h" #include @@ -37,36 +37,35 @@ ChatMessage::ChatMessage() { - } -ChatMessage::Ptr ChatMessage::createChatMessage(const QString &sender, const QString &rawMessage, MessageType type, bool isMe, const QDateTime &date) +ChatMessage::Ptr ChatMessage::createChatMessage(const QString& sender, const QString& rawMessage, + MessageType type, bool isMe, const QDateTime& date) { ChatMessage::Ptr msg = ChatMessage::Ptr(new ChatMessage); QString text = rawMessage.toHtmlEscaped(); QString senderText = sender; - const QColor actionColor = QColor("#1818FF"); // has to match the color in innerStyle.css (div.action) + const QColor actionColor = + QColor("#1818FF"); // has to match the color in innerStyle.css (div.action) - //smileys + // smileys if (Settings::getInstance().getUseEmoticons()) text = SmileyPack::getInstance().smileyfied(text); - //quotes (green text) + // quotes (green text) text = detectQuotes(detectAnchors(text), type); - //text styling + // text styling Settings::StyleType styleType = Settings::getInstance().getStylePreference(); - if (styleType != Settings::StyleType::NONE) - { + if (styleType != Settings::StyleType::NONE) { TextFormatter tf = TextFormatter(text); text = tf.applyStyling(styleType == Settings::StyleType::WITH_CHARS); } - switch(type) - { + switch (type) { case NORMAL: text = wrapDiv(text, "msg"); break; @@ -86,9 +85,15 @@ ChatMessage::Ptr ChatMessage::createChatMessage(const QString &sender, const QSt if (isMe) authorFont.setBold(true); - msg->addColumn(new Text(senderText, authorFont, true, sender, type == ACTION ? actionColor : Qt::black), ColumnFormat(NAME_COL_WIDTH, ColumnFormat::FixedSize, ColumnFormat::Right)); - msg->addColumn(new Text(text, baseFont, false, ((type == ACTION) && isMe) ? QString("%1 %2").arg(sender, rawMessage) : rawMessage), ColumnFormat(1.0, ColumnFormat::VariableSize)); - msg->addColumn(new Spinner(":/ui/chatArea/spinner.svg", QSize(16, 16), 360.0/1.6), ColumnFormat(TIME_COL_WIDTH, ColumnFormat::FixedSize, ColumnFormat::Right)); + msg->addColumn(new Text(senderText, authorFont, true, sender, + type == ACTION ? actionColor : Qt::black), + ColumnFormat(NAME_COL_WIDTH, ColumnFormat::FixedSize, ColumnFormat::Right)); + msg->addColumn(new Text(text, baseFont, false, ((type == ACTION) && isMe) + ? QString("%1 %2").arg(sender, rawMessage) + : rawMessage), + ColumnFormat(1.0, ColumnFormat::VariableSize)); + msg->addColumn(new Spinner(":/ui/chatArea/spinner.svg", QSize(16, 16), 360.0 / 1.6), + ColumnFormat(TIME_COL_WIDTH, ColumnFormat::FixedSize, ColumnFormat::Right)); if (!date.isNull()) msg->markAsSent(date); @@ -96,29 +101,39 @@ ChatMessage::Ptr ChatMessage::createChatMessage(const QString &sender, const QSt return msg; } -ChatMessage::Ptr ChatMessage::createChatInfoMessage(const QString &rawMessage, SystemMessageType type, const QDateTime &date) +ChatMessage::Ptr ChatMessage::createChatInfoMessage(const QString& rawMessage, + SystemMessageType type, const QDateTime& date) { ChatMessage::Ptr msg = ChatMessage::Ptr(new ChatMessage); QString text = rawMessage.toHtmlEscaped(); QString img; - switch(type) - { - case INFO: img = ":/ui/chatArea/info.svg"; break; - case ERROR: img = ":/ui/chatArea/error.svg"; break; - case TYPING: img = ":/ui/chatArea/typing.svg"; break; + switch (type) { + case INFO: + img = ":/ui/chatArea/info.svg"; + break; + case ERROR: + img = ":/ui/chatArea/error.svg"; + break; + case TYPING: + img = ":/ui/chatArea/typing.svg"; + break; } QFont baseFont = Settings::getInstance().getChatMessageFont(); - msg->addColumn(new Image(QSize(18, 18), img), ColumnFormat(NAME_COL_WIDTH, ColumnFormat::FixedSize, ColumnFormat::Right)); - msg->addColumn(new Text("" + text + "", baseFont, false, ""), ColumnFormat(1.0, ColumnFormat::VariableSize, ColumnFormat::Left)); - msg->addColumn(new Timestamp(date, Settings::getInstance().getTimestampFormat(), baseFont), ColumnFormat(TIME_COL_WIDTH, ColumnFormat::FixedSize, ColumnFormat::Right)); + msg->addColumn(new Image(QSize(18, 18), img), + ColumnFormat(NAME_COL_WIDTH, ColumnFormat::FixedSize, ColumnFormat::Right)); + msg->addColumn(new Text("" + text + "", baseFont, false, ""), + ColumnFormat(1.0, ColumnFormat::VariableSize, ColumnFormat::Left)); + msg->addColumn(new Timestamp(date, Settings::getInstance().getTimestampFormat(), baseFont), + ColumnFormat(TIME_COL_WIDTH, ColumnFormat::FixedSize, ColumnFormat::Right)); return msg; } -ChatMessage::Ptr ChatMessage::createFileTransferMessage(const QString& sender, ToxFile file, bool isMe, const QDateTime& date) +ChatMessage::Ptr ChatMessage::createFileTransferMessage(const QString& sender, ToxFile file, + bool isMe, const QDateTime& date) { ChatMessage::Ptr msg = ChatMessage::Ptr(new ChatMessage); @@ -127,9 +142,12 @@ ChatMessage::Ptr ChatMessage::createFileTransferMessage(const QString& sender, T if (isMe) authorFont.setBold(true); - msg->addColumn(new Text(sender, authorFont, true), ColumnFormat(NAME_COL_WIDTH, ColumnFormat::FixedSize, ColumnFormat::Right)); - msg->addColumn(new ChatLineContentProxy(new FileTransferWidget(0, file), 320, 0.6f), ColumnFormat(1.0, ColumnFormat::VariableSize)); - msg->addColumn(new Timestamp(date, Settings::getInstance().getTimestampFormat(), baseFont), ColumnFormat(TIME_COL_WIDTH, ColumnFormat::FixedSize, ColumnFormat::Right)); + msg->addColumn(new Text(sender, authorFont, true), + ColumnFormat(NAME_COL_WIDTH, ColumnFormat::FixedSize, ColumnFormat::Right)); + msg->addColumn(new ChatLineContentProxy(new FileTransferWidget(0, file), 320, 0.6f), + ColumnFormat(1.0, ColumnFormat::VariableSize)); + msg->addColumn(new Timestamp(date, Settings::getInstance().getTimestampFormat(), baseFont), + ColumnFormat(TIME_COL_WIDTH, ColumnFormat::FixedSize, ColumnFormat::Right)); return msg; } @@ -140,14 +158,17 @@ ChatMessage::Ptr ChatMessage::createTypingNotification() QFont baseFont = Settings::getInstance().getChatMessageFont(); - // Note: "[user]..." is just a placeholder. The actual text is set in ChatForm::setFriendTyping() + // Note: "[user]..." is just a placeholder. The actual text is set in + // ChatForm::setFriendTyping() // // FIXME: Due to circumstances, placeholder is being used in a case where // user received typing notifications constantly since contact came online. // This causes "[user]..." to be displayed in place of user nick, as long // as user will keep typing. Issue #1280 - msg->addColumn(new NotificationIcon(QSize(18, 18)), ColumnFormat(NAME_COL_WIDTH, ColumnFormat::FixedSize, ColumnFormat::Right)); - msg->addColumn(new Text("[user]...", baseFont, false, ""), ColumnFormat(1.0, ColumnFormat::VariableSize, ColumnFormat::Left)); + msg->addColumn(new NotificationIcon(QSize(18, 18)), + ColumnFormat(NAME_COL_WIDTH, ColumnFormat::FixedSize, ColumnFormat::Right)); + msg->addColumn(new Text("[user]...", baseFont, false, ""), + ColumnFormat(1.0, ColumnFormat::VariableSize, ColumnFormat::Left)); return msg; } @@ -159,12 +180,13 @@ ChatMessage::Ptr ChatMessage::createBusyNotification() baseFont.setPixelSize(baseFont.pixelSize() + 2); baseFont.setBold(true); - msg->addColumn(new Text(QObject::tr("Resizing"), baseFont, false, ""), ColumnFormat(1.0, ColumnFormat::VariableSize, ColumnFormat::Center)); + msg->addColumn(new Text(QObject::tr("Resizing"), baseFont, false, ""), + ColumnFormat(1.0, ColumnFormat::VariableSize, ColumnFormat::Center)); return msg; } -void ChatMessage::markAsSent(const QDateTime &time) +void ChatMessage::markAsSent(const QDateTime& time) { QFont baseFont = Settings::getInstance().getChatMessageFont(); @@ -205,30 +227,29 @@ void ChatMessage::hideDate() c->hide(); } -QString ChatMessage::detectAnchors(const QString &str) +QString ChatMessage::detectAnchors(const QString& str) { QString out = str; // detect URIs - QRegExp exp("(" - "(?:\\b)((www\\.)|(http[s]?|ftp)://)" // (protocol)://(printable - non-special character) - // http://ONEORMOREALHPA-DIGIT - "\\w+\\S+)" // any other character, lets domains and other - // ↓ link to a file, or samba share - // https://en.wikipedia.org/wiki/File_URI_scheme - "|(?:\\b)((file|smb)://)([\\S| ]*)" - "|(?:\\b)(tox:[a-zA-Z\\d]{76})" //link with full user address - "|(?:\\b)(mailto:\\S+@\\S+\\.\\S+)" //@mail link - "|(?:\\b)(tox:\\S+@\\S+)"); // starts with `tox` then : and only alpha-digits till the end - // also accepts tox:agilob@net as simplified TOX ID + QRegExp exp( + "(" + "(?:\\b)((www\\.)|(http[s]?|ftp)://)" // (protocol)://(printable - non-special character) + // http://ONEORMOREALHPA-DIGIT + "\\w+\\S+)" // any other character, lets domains and other + // ↓ link to a file, or samba share + // https://en.wikipedia.org/wiki/File_URI_scheme + "|(?:\\b)((file|smb)://)([\\S| ]*)" + "|(?:\\b)(tox:[a-zA-Z\\d]{76})" // link with full user address + "|(?:\\b)(mailto:\\S+@\\S+\\.\\S+)" //@mail link + "|(?:\\b)(tox:\\S+@\\S+)"); // starts with `tox` then : and only alpha-digits till the end + // also accepts tox:agilob@net as simplified TOX ID int offset = 0; - while ((offset = exp.indexIn(out, offset)) != -1) - { + while ((offset = exp.indexIn(out, offset)) != -1) { QString url = exp.cap(); // If there's a trailing " it's a HTML attribute, e.g. a smiley img's title=":tox:" - if (url == "tox:\"") - { + if (url == "tox:\"") { offset += url.length(); continue; } @@ -250,25 +271,20 @@ QString ChatMessage::detectQuotes(const QString& str, MessageType type) // detect text quotes QStringList messageLines = str.split("\n"); QString quotedText; - for (int i = 0; i < messageLines.size(); ++i) - { + for (int i = 0; i < messageLines.size(); ++i) { // don't quote first line in action message. This makes co-existence of // quotes and action messages possible, since only first line can cause // problems in case where there is quote in it used. - if (QRegExp("^(>|>).*").exactMatch(messageLines[i])) - { + if (QRegExp("^(>|>).*").exactMatch(messageLines[i])) { if (i > 0 || type != ACTION) quotedText += "" + messageLines[i] + ""; else quotedText += messageLines[i]; - } - else - { + } else { quotedText += messageLines[i]; } - if (i < messageLines.size() - 1) - { + if (i < messageLines.size() - 1) { quotedText += '\n'; } } @@ -276,7 +292,7 @@ QString ChatMessage::detectQuotes(const QString& str, MessageType type) return quotedText; } -QString ChatMessage::wrapDiv(const QString &str, const QString &div) +QString ChatMessage::wrapDiv(const QString& str, const QString& div) { - return QString("

%2

").arg(div, /*QChar(0x200E) + */QString(str)); + return QString("

%2

").arg(div, /*QChar(0x200E) + */ QString(str)); } diff --git a/src/chatlog/chatmessage.h b/src/chatlog/chatmessage.h index 562c8ca31..310d01b81 100644 --- a/src/chatlog/chatmessage.h +++ b/src/chatlog/chatmessage.h @@ -47,9 +47,13 @@ public: ChatMessage(); - static ChatMessage::Ptr createChatMessage(const QString& sender, const QString& rawMessage, MessageType type, bool isMe, const QDateTime& date = QDateTime()); - static ChatMessage::Ptr createChatInfoMessage(const QString& rawMessage, SystemMessageType type, const QDateTime& date); - static ChatMessage::Ptr createFileTransferMessage(const QString& sender, ToxFile file, bool isMe, const QDateTime& date); + static ChatMessage::Ptr createChatMessage(const QString& sender, const QString& rawMessage, + MessageType type, bool isMe, + const QDateTime& date = QDateTime()); + static ChatMessage::Ptr createChatInfoMessage(const QString& rawMessage, SystemMessageType type, + const QDateTime& date); + static ChatMessage::Ptr createFileTransferMessage(const QString& sender, ToxFile file, + bool isMe, const QDateTime& date); static ChatMessage::Ptr createTypingNotification(); static ChatMessage::Ptr createBusyNotification(); diff --git a/src/chatlog/content/filetransferwidget.cpp b/src/chatlog/content/filetransferwidget.cpp index bb03052f8..de3217faf 100644 --- a/src/chatlog/content/filetransferwidget.cpp +++ b/src/chatlog/content/filetransferwidget.cpp @@ -20,23 +20,23 @@ #include "filetransferwidget.h" #include "ui_filetransferwidget.h" -#include "src/nexus.h" #include "src/core/core.h" +#include "src/nexus.h" +#include "src/persistence/settings.h" #include "src/widget/gui.h" #include "src/widget/style.h" #include "src/widget/widget.h" -#include "src/persistence/settings.h" -#include -#include -#include #include -#include +#include #include #include +#include +#include +#include +#include #include #include -#include #include @@ -63,10 +63,11 @@ FileTransferWidget::FileTransferWidget(QWidget* parent, ToxFile file) backgroundColorAnimation = new QVariantAnimation(this); backgroundColorAnimation->setDuration(500); backgroundColorAnimation->setEasingCurve(QEasingCurve::OutCubic); - connect(backgroundColorAnimation, &QVariantAnimation::valueChanged, this, [this](const QVariant& val) { - backgroundColor = val.value(); - update(); - }); + connect(backgroundColorAnimation, &QVariantAnimation::valueChanged, this, + [this](const QVariant& val) { + backgroundColor = val.value(); + update(); + }); buttonColorAnimation = new QVariantAnimation(this); buttonColorAnimation->setDuration(500); @@ -78,27 +79,32 @@ FileTransferWidget::FileTransferWidget(QWidget* parent, ToxFile file) setBackgroundColor(Style::getColor(Style::LightGrey), false); - connect(Core::getInstance(), &Core::fileTransferInfo, this, &FileTransferWidget::onFileTransferInfo); - connect(Core::getInstance(), &Core::fileTransferAccepted, this, &FileTransferWidget::onFileTransferAccepted); - connect(Core::getInstance(), &Core::fileTransferCancelled, this, &FileTransferWidget::onFileTransferCancelled); - connect(Core::getInstance(), &Core::fileTransferPaused, this, &FileTransferWidget::onFileTransferPaused); - connect(Core::getInstance(), &Core::fileTransferFinished, this, &FileTransferWidget::onFileTransferFinished); - connect(Core::getInstance(), &Core::fileTransferRemotePausedUnpaused, this, &FileTransferWidget::fileTransferRemotePausedUnpaused); - connect(Core::getInstance(), &Core::fileTransferBrokenUnbroken, this, &FileTransferWidget::fileTransferBrokenUnbroken); + connect(Core::getInstance(), &Core::fileTransferInfo, this, + &FileTransferWidget::onFileTransferInfo); + connect(Core::getInstance(), &Core::fileTransferAccepted, this, + &FileTransferWidget::onFileTransferAccepted); + connect(Core::getInstance(), &Core::fileTransferCancelled, this, + &FileTransferWidget::onFileTransferCancelled); + connect(Core::getInstance(), &Core::fileTransferPaused, this, + &FileTransferWidget::onFileTransferPaused); + connect(Core::getInstance(), &Core::fileTransferFinished, this, + &FileTransferWidget::onFileTransferFinished); + connect(Core::getInstance(), &Core::fileTransferRemotePausedUnpaused, this, + &FileTransferWidget::fileTransferRemotePausedUnpaused); + connect(Core::getInstance(), &Core::fileTransferBrokenUnbroken, this, + &FileTransferWidget::fileTransferBrokenUnbroken); connect(ui->topButton, &QPushButton::clicked, this, &FileTransferWidget::onTopButtonClicked); connect(ui->bottomButton, &QPushButton::clicked, this, &FileTransferWidget::onBottomButtonClicked); - connect(ui->previewButton, &QPushButton::clicked, this, &FileTransferWidget::onPreviewButtonClicked); + connect(ui->previewButton, &QPushButton::clicked, this, + &FileTransferWidget::onPreviewButtonClicked); setupButtons(); - //preview - if (fileInfo.direction == ToxFile::SENDING) - { + // preview + if (fileInfo.direction == ToxFile::SENDING) { showPreview(fileInfo.filePath); ui->progressLabel->setText(tr("Waiting to send...", "file transfer widget")); - } - else - { + } else { ui->progressLabel->setText(tr("Accept to receive this file", "file transfer widget")); } @@ -110,7 +116,7 @@ FileTransferWidget::~FileTransferWidget() delete ui; } -void FileTransferWidget::autoAcceptTransfer(const QString &path) +void FileTransferWidget::autoAcceptTransfer(const QString& path) { QString filepath; int number = 0; @@ -118,15 +124,16 @@ void FileTransferWidget::autoAcceptTransfer(const QString &path) QString suffix = QFileInfo(fileInfo.fileName).completeSuffix(); QString base = QFileInfo(fileInfo.fileName).baseName(); - do - { - filepath = QString("%1/%2%3.%4").arg(path, base, number > 0 ? QString(" (%1)").arg(QString::number(number)) : QString(), suffix); + do { + filepath = QString("%1/%2%3.%4") + .arg(path, base, + number > 0 ? QString(" (%1)").arg(QString::number(number)) : QString(), + suffix); ++number; - } - while (QFileInfo(filepath).exists()); + } while (QFileInfo(filepath).exists()); - //Do not automatically accept the file-transfer if the path is not writable. - //The user can still accept it manually. + // Do not automatically accept the file-transfer if the path is not writable. + // The user can still accept it manually. if (Nexus::tryRemoveFile(filepath)) Core::getInstance()->acceptFileRecvRequest(fileInfo.friendId, fileInfo.fileNum, filepath); else @@ -138,27 +145,27 @@ bool FileTransferWidget::isActive() const return active; } -void FileTransferWidget::acceptTransfer(const QString &filepath) +void FileTransferWidget::acceptTransfer(const QString& filepath) { if (filepath.isEmpty()) return; - //test if writable - if (!Nexus::tryRemoveFile(filepath)) - { + // test if writable + if (!Nexus::tryRemoveFile(filepath)) { GUI::showWarning(tr("Location not writable", "Title of permissions popup"), - tr("You do not have permission to write that location. Choose another, or cancel the save dialog.", "text of permissions popup")); + tr("You do not have permission to write that location. Choose another, or " + "cancel the save dialog.", + "text of permissions popup")); return; } - //everything ok! + // everything ok! Core::getInstance()->acceptFileRecvRequest(fileInfo.friendId, fileInfo.fileNum, filepath); } -void FileTransferWidget::setBackgroundColor(const QColor &c, bool whiteFont) +void FileTransferWidget::setBackgroundColor(const QColor& c, bool whiteFont) { - if (c != backgroundColor) - { + if (c != backgroundColor) { backgroundColorAnimation->setStartValue(backgroundColor); backgroundColorAnimation->setEndValue(c); backgroundColorAnimation->start(); @@ -172,10 +179,9 @@ void FileTransferWidget::setBackgroundColor(const QColor &c, bool whiteFont) update(); } -void FileTransferWidget::setButtonColor(const QColor &c) +void FileTransferWidget::setButtonColor(const QColor& c) { - if (c != buttonColor) - { + if (c != buttonColor) { buttonColorAnimation->setStartValue(buttonColor); buttonColorAnimation->setEndValue(c); buttonColorAnimation->start(); @@ -184,11 +190,11 @@ void FileTransferWidget::setButtonColor(const QColor &c) bool FileTransferWidget::drawButtonAreaNeeded() const { - return (ui->bottomButton->isVisible() || ui->topButton->isVisible()) && - !(ui->topButton->isVisible() && ui->topButton->objectName() == "ok"); + return (ui->bottomButton->isVisible() || ui->topButton->isVisible()) + && !(ui->topButton->isVisible() && ui->topButton->objectName() == "ok"); } -void FileTransferWidget::paintEvent(QPaintEvent *) +void FileTransferWidget::paintEvent(QPaintEvent*) { // required by Hi-DPI support as border-image doesn't work. QPainter painter(this); @@ -202,21 +208,22 @@ void FileTransferWidget::paintEvent(QPaintEvent *) // draw background if (drawButtonAreaNeeded()) - painter.setClipRect(QRect(0, 0, width()-buttonFieldWidth, height())); + painter.setClipRect(QRect(0, 0, width() - buttonFieldWidth, height())); painter.setBrush(QBrush(backgroundColor)); painter.drawRoundRect(geometry(), r * ratio, r); - if (drawButtonAreaNeeded()) - { + if (drawButtonAreaNeeded()) { // draw button background (top) painter.setBrush(QBrush(buttonColor)); - painter.setClipRect(QRect(width()-buttonFieldWidth+lineWidth,0,buttonFieldWidth,height()/2-ceil(lineWidth/2.0))); + painter.setClipRect(QRect(width() - buttonFieldWidth + lineWidth, 0, buttonFieldWidth, + height() / 2 - ceil(lineWidth / 2.0))); painter.drawRoundRect(geometry(), r * ratio, r); // draw button background (bottom) painter.setBrush(QBrush(buttonColor)); - painter.setClipRect(QRect(width()-buttonFieldWidth+lineWidth,height()/2+lineWidth/2,buttonFieldWidth,height()/2)); + painter.setClipRect(QRect(width() - buttonFieldWidth + lineWidth, + height() / 2 + lineWidth / 2, buttonFieldWidth, height() / 2)); painter.drawRoundRect(geometry(), r * ratio, r); } } @@ -224,15 +231,14 @@ void FileTransferWidget::paintEvent(QPaintEvent *) void FileTransferWidget::onFileTransferInfo(ToxFile file) { QTime now = QTime::currentTime(); - qint64 dt = lastTick.msecsTo(now); //ms + qint64 dt = lastTick.msecsTo(now); // ms if (fileInfo != file || dt < 1000) return; fileInfo = file; - if (fileInfo.status == ToxFile::TRANSMITTING) - { + if (fileInfo.status == ToxFile::TRANSMITTING) { // update progress qreal progress = static_cast(file.bytesSent) / static_cast(file.filesize); ui->progressBar->setValue(static_cast(progress * 100.0)); @@ -241,9 +247,8 @@ void FileTransferWidget::onFileTransferInfo(ToxFile file) qreal deltaSecs = dt / 1000.0; // (can't use ::abs or ::max on unsigned types substraction, they'd just overflow) - quint64 deltaBytes = file.bytesSent > lastBytesSent - ? file.bytesSent - lastBytesSent - : lastBytesSent - file.bytesSent; + quint64 deltaBytes = file.bytesSent > lastBytesSent ? file.bytesSent - lastBytesSent + : lastBytesSent - file.bytesSent; qreal bytesPerSec = static_cast(static_cast(deltaBytes) / deltaSecs); // calculate mean @@ -257,15 +262,12 @@ void FileTransferWidget::onFileTransferInfo(ToxFile file) meanBytesPerSec /= static_cast(TRANSFER_ROLLING_AVG_COUNT); // update UI - if (meanBytesPerSec > 0) - { + if (meanBytesPerSec > 0) { // ETA - QTime toGo = QTime(0,0).addSecs((file.filesize - file.bytesSent) / meanBytesPerSec); + QTime toGo = QTime(0, 0).addSecs((file.filesize - file.bytesSent) / meanBytesPerSec); QString format = toGo.hour() > 0 ? "hh:mm:ss" : "mm:ss"; ui->etaLabel->setText(toGo.toString(format)); - } - else - { + } else { ui->etaLabel->setText(""); } @@ -320,7 +322,7 @@ void FileTransferWidget::onFileTransferPaused(ToxFile file) // reset mean meanIndex = 0; - for (size_t i=0; i 0) - exp = std::min( (int) (log(size) / log(1024)), (int) (sizeof(suffix) / sizeof(suffix[0]) - 1)); + exp = std::min((int)(log(size) / log(1024)), (int)(sizeof(suffix) / sizeof(suffix[0]) - 1)); return QString().setNum(size / pow(1024, exp), 'f', exp > 1 ? 2 : 0).append(suffix[exp]); } @@ -415,8 +417,7 @@ void FileTransferWidget::hideWidgets() void FileTransferWidget::setupButtons() { - switch(fileInfo.status) - { + switch (fileInfo.status) { case ToxFile::TRANSMITTING: ui->topButton->setIcon(QIcon(":/ui/fileTransferInstance/pause.svg")); ui->topButton->setObjectName("pause"); @@ -447,14 +448,11 @@ void FileTransferWidget::setupButtons() ui->bottomButton->setObjectName("cancel"); ui->bottomButton->setToolTip(tr("Cancel transfer")); - if (fileInfo.direction == ToxFile::SENDING) - { + if (fileInfo.direction == ToxFile::SENDING) { ui->topButton->setIcon(QIcon(":/ui/fileTransferInstance/pause.svg")); ui->topButton->setObjectName("pause"); ui->topButton->setToolTip(tr("Pause transfer")); - } - else - { + } else { ui->topButton->setIcon(QIcon(":/ui/fileTransferInstance/yes.svg")); ui->topButton->setObjectName("accept"); ui->topButton->setToolTip(tr("Accept transfer")); @@ -463,18 +461,16 @@ void FileTransferWidget::setupButtons() } } -void FileTransferWidget::handleButton(QPushButton *btn) +void FileTransferWidget::handleButton(QPushButton* btn) { - if (fileInfo.direction == ToxFile::SENDING) - { + if (fileInfo.direction == ToxFile::SENDING) { if (btn->objectName() == "cancel") Core::getInstance()->cancelFileSend(fileInfo.friendId, fileInfo.fileNum); else if (btn->objectName() == "pause") Core::getInstance()->pauseResumeFileSend(fileInfo.friendId, fileInfo.fileNum); else if (btn->objectName() == "resume") Core::getInstance()->pauseResumeFileSend(fileInfo.friendId, fileInfo.fileNum); - } - else // receiving or paused + } else // receiving or paused { if (btn->objectName() == "cancel") Core::getInstance()->cancelFileRecv(fileInfo.friendId, fileInfo.fileNum); @@ -482,37 +478,31 @@ void FileTransferWidget::handleButton(QPushButton *btn) Core::getInstance()->pauseResumeFileRecv(fileInfo.friendId, fileInfo.fileNum); else if (btn->objectName() == "resume") Core::getInstance()->pauseResumeFileRecv(fileInfo.friendId, fileInfo.fileNum); - else if (btn->objectName() == "accept") - { - QString path = QFileDialog::getSaveFileName(parentWidget(), - tr("Save a file", "Title of the file saving dialog"), - Settings::getInstance().getGlobalAutoAcceptDir() + "/" + fileInfo.fileName, - 0, - 0, - QFileDialog::DontUseNativeDialog); + else if (btn->objectName() == "accept") { + QString path = + QFileDialog::getSaveFileName(parentWidget(), + tr("Save a file", "Title of the file saving dialog"), + Settings::getInstance().getGlobalAutoAcceptDir() + "/" + + fileInfo.fileName, + 0, 0, QFileDialog::DontUseNativeDialog); acceptTransfer(path); } } - if (btn->objectName() == "ok" || btn->objectName() == "previewButton") - { + if (btn->objectName() == "ok" || btn->objectName() == "previewButton") { Widget::confirmExecutableOpen(QFileInfo(fileInfo.filePath)); - } - else if (btn->objectName() == "dir") - { + } else if (btn->objectName() == "dir") { QString dirPath = QFileInfo(fileInfo.filePath).dir().path(); QDesktopServices::openUrl(QUrl::fromLocalFile(dirPath)); } - } -void FileTransferWidget::showPreview(const QString &filename) +void FileTransferWidget::showPreview(const QString& filename) { - static const QStringList previewExtensions = { "png", "jpeg", "jpg", "gif", "svg", - "PNG", "JPEG", "JPG", "GIF", "SVG" }; + static const QStringList previewExtensions = {"png", "jpeg", "jpg", "gif", "svg", + "PNG", "JPEG", "JPG", "GIF", "SVG"}; - if (previewExtensions.contains(QFileInfo(filename).suffix())) - { + if (previewExtensions.contains(QFileInfo(filename).suffix())) { // Subtract to make border visible const int size = qMax(ui->previewButton->width(), ui->previewButton->height()) - 4; @@ -524,15 +514,15 @@ void FileTransferWidget::showPreview(const QString &filename) ui->previewButton->show(); // Show mouseover preview, but make sure it's not larger than 50% of the screen width/height const QRect desktopSize = QApplication::desktop()->screenGeometry(); - const QImage previewImage = image.scaled(0.5 * desktopSize.width(), - 0.5 * desktopSize.height(), - Qt::KeepAspectRatio, Qt::SmoothTransformation); + const QImage previewImage = image.scaled(0.5 * desktopSize.width(), 0.5 * desktopSize.height(), + Qt::KeepAspectRatio, Qt::SmoothTransformation); QByteArray imageData; QBuffer buffer(&imageData); buffer.open(QIODevice::WriteOnly); previewImage.save(&buffer, "PNG"); buffer.close(); - ui->previewButton->setToolTip(""); + ui->previewButton->setToolTip(""); } } @@ -551,19 +541,15 @@ void FileTransferWidget::onPreviewButtonClicked() handleButton(ui->previewButton); } -QPixmap FileTransferWidget::scaleCropIntoSquare(const QPixmap &source, const int targetSize) +QPixmap FileTransferWidget::scaleCropIntoSquare(const QPixmap& source, const int targetSize) { QPixmap result; // Make sure smaller-than-icon images (at least one dimension is smaller) will not be upscaled - if (source.width() < targetSize || source.height() < targetSize) - { + if (source.width() < targetSize || source.height() < targetSize) { result = source; - } - else - { - result = source.scaled(targetSize, targetSize, - Qt::KeepAspectRatioByExpanding, + } else { + result = source.scaled(targetSize, targetSize, Qt::KeepAspectRatioByExpanding, Qt::SmoothTransformation); } diff --git a/src/chatlog/content/filetransferwidget.h b/src/chatlog/content/filetransferwidget.h index 2a74b3bb2..aec13ed9f 100644 --- a/src/chatlog/content/filetransferwidget.h +++ b/src/chatlog/content/filetransferwidget.h @@ -20,8 +20,8 @@ #ifndef FILETRANSFERWIDGET_H #define FILETRANSFERWIDGET_H -#include #include +#include #include "src/chatlog/chatlinecontent.h" #include "src/core/corestructs.h" @@ -74,10 +74,10 @@ private slots: void onPreviewButtonClicked(); private: - static QPixmap scaleCropIntoSquare(const QPixmap &source, int targetSize); + static QPixmap scaleCropIntoSquare(const QPixmap& source, int targetSize); private: - Ui::FileTransferWidget *ui; + Ui::FileTransferWidget* ui; ToxFile fileInfo; QTime lastTick; quint64 lastBytesSent = 0; diff --git a/src/chatlog/content/image.h b/src/chatlog/content/image.h index f7dbc8b4c..d457a3f6f 100644 --- a/src/chatlog/content/image.h +++ b/src/chatlog/content/image.h @@ -27,17 +27,17 @@ class Image : public ChatLineContent { public: - Image(QSize size, const QString &filename); + Image(QSize size, const QString& filename); virtual QRectF boundingRect() const override; - virtual void paint(QPainter* painter, const QStyleOptionGraphicsItem* option, QWidget* widget) override; + virtual void paint(QPainter* painter, const QStyleOptionGraphicsItem* option, + QWidget* widget) override; virtual void setWidth(qreal width) override; virtual qreal getAscent() const override; private: QSize size; QPixmap pmap; - }; #endif // IMAGE_H diff --git a/src/chatlog/content/notificationicon.cpp b/src/chatlog/content/notificationicon.cpp index 6e683b580..48524f7a4 100644 --- a/src/chatlog/content/notificationicon.cpp +++ b/src/chatlog/content/notificationicon.cpp @@ -20,9 +20,9 @@ #include "notificationicon.h" #include "../pixmapcache.h" +#include #include #include -#include NotificationIcon::NotificationIcon(QSize Size) : size(Size) @@ -30,7 +30,7 @@ NotificationIcon::NotificationIcon(QSize Size) pmap = PixmapCache::getInstance().get(":/ui/chatArea/typing.svg", size); updateTimer = new QTimer(this); - updateTimer->setInterval(1000/30); + updateTimer->setInterval(1000 / 30); updateTimer->setSingleShot(false); updateTimer->start(); @@ -74,7 +74,7 @@ void NotificationIcon::updateGradient() if (alpha + dotWidth >= 1.0) alpha = 0.0; - grad = QLinearGradient(QPointF(-0.5*size.width(),0), QPointF(3.0/2.0*size.width(),0)); + grad = QLinearGradient(QPointF(-0.5 * size.width(), 0), QPointF(3.0 / 2.0 * size.width(), 0)); grad.setColorAt(0, Qt::lightGray); grad.setColorAt(qMax(0.0, alpha - dotWidth), Qt::lightGray); grad.setColorAt(alpha, Qt::black); diff --git a/src/chatlog/content/notificationicon.h b/src/chatlog/content/notificationicon.h index 3fdcfcaf1..8288805d6 100644 --- a/src/chatlog/content/notificationicon.h +++ b/src/chatlog/content/notificationicon.h @@ -34,7 +34,8 @@ public: explicit NotificationIcon(QSize size); virtual QRectF boundingRect() const override; - virtual void paint(QPainter* painter, const QStyleOptionGraphicsItem* option, QWidget* widget) override; + virtual void paint(QPainter* painter, const QStyleOptionGraphicsItem* option, + QWidget* widget) override; virtual void setWidth(qreal width) override; virtual qreal getAscent() const override; @@ -49,7 +50,6 @@ private: qreal dotWidth = 0.2; qreal alpha = 0.0; - }; #endif // NOTIFICATIONICON_H diff --git a/src/chatlog/content/spinner.cpp b/src/chatlog/content/spinner.cpp index 34107ef55..28542371b 100644 --- a/src/chatlog/content/spinner.cpp +++ b/src/chatlog/content/spinner.cpp @@ -20,19 +20,19 @@ #include "spinner.h" #include "../pixmapcache.h" -#include +#include #include +#include #include #include -#include -Spinner::Spinner(const QString &img, QSize Size, qreal speed) +Spinner::Spinner(const QString& img, QSize Size, qreal speed) : size(Size) , rotSpeed(speed) { pmap = PixmapCache::getInstance().get(img, size); - timer.setInterval(1000/30); // 30Hz + timer.setInterval(1000 / 30); // 30Hz timer.setSingleShot(false); blendAnimation = new QVariantAnimation(this); @@ -41,7 +41,8 @@ Spinner::Spinner(const QString &img, QSize Size, qreal speed) blendAnimation->setDuration(350); blendAnimation->setEasingCurve(QEasingCurve::InCubic); blendAnimation->start(QAbstractAnimation::DeleteWhenStopped); - connect(blendAnimation, &QVariantAnimation::valueChanged, this, [this](const QVariant& val) { alpha = val.toDouble(); }); + connect(blendAnimation, &QVariantAnimation::valueChanged, this, + [this](const QVariant& val) { alpha = val.toDouble(); }); QObject::connect(&timer, &QTimer::timeout, this, &Spinner::timeout); } @@ -55,8 +56,9 @@ void Spinner::paint(QPainter* painter, const QStyleOptionGraphicsItem* option, Q { painter->setClipRect(boundingRect()); - QTransform trans = QTransform().rotate(QTime::currentTime().msecsSinceStartOfDay() / 1000.0 * rotSpeed) - .translate(-size.width()/2.0, -size.height()/2.0); + QTransform trans = QTransform() + .rotate(QTime::currentTime().msecsSinceStartOfDay() / 1000.0 * rotSpeed) + .translate(-size.width() / 2.0, -size.height() / 2.0); painter->setOpacity(alpha); painter->setTransform(trans, true); painter->setRenderHint(QPainter::SmoothPixmapTransform); diff --git a/src/chatlog/content/spinner.h b/src/chatlog/content/spinner.h index caab0850a..8c04359bc 100644 --- a/src/chatlog/content/spinner.h +++ b/src/chatlog/content/spinner.h @@ -22,9 +22,9 @@ #include "../chatlinecontent.h" -#include #include #include +#include class QVariantAnimation; @@ -35,7 +35,8 @@ public: Spinner(const QString& img, QSize size, qreal speed); virtual QRectF boundingRect() const override; - virtual void paint(QPainter* painter, const QStyleOptionGraphicsItem* option, QWidget* widget) override; + virtual void paint(QPainter* painter, const QStyleOptionGraphicsItem* option, + QWidget* widget) override; virtual void setWidth(qreal width) override; virtual void visibilityChanged(bool visible) override; virtual qreal getAscent() const override; @@ -50,7 +51,6 @@ private: QTimer timer; qreal alpha = 0.0; QVariantAnimation* blendAnimation; - }; #endif // SPINNER_H diff --git a/src/chatlog/content/text.cpp b/src/chatlog/content/text.cpp index fe28bf7e2..005709f03 100644 --- a/src/chatlog/content/text.cpp +++ b/src/chatlog/content/text.cpp @@ -20,20 +20,21 @@ #include "text.h" #include "../documentcache.h" -#include -#include -#include -#include -#include #include #include -#include +#include #include +#include +#include +#include +#include +#include #include #include "src/widget/style.h" -Text::Text(const QString& txt, const QFont& font, bool enableElide, const QString &rwText, const QColor c) +Text::Text(const QString& txt, const QFont& font, bool enableElide, const QString& rwText, + const QColor c) : rawText(rwText) , elide(enableElide) , defFont(font) @@ -71,8 +72,7 @@ void Text::selectionMouseMove(QPointF scenePos) return; int cur = cursorFromPos(scenePos); - if (cur >= 0) - { + if (cur >= 0) { selectionEnd = cur; selectedText = extractSanitizedText(getSelectionStart(), getSelectionEnd()); } @@ -83,8 +83,7 @@ void Text::selectionMouseMove(QPointF scenePos) void Text::selectionStarted(QPointF scenePos) { int cur = cursorFromPos(scenePos); - if (cur >= 0) - { + if (cur >= 0) { selectionEnd = cur; selectionAnchor = cur; } @@ -108,8 +107,7 @@ void Text::selectionDoubleClick(QPointF scenePos) int cur = cursorFromPos(scenePos); - if (cur >= 0) - { + if (cur >= 0) { QTextCursor cursor(doc); cursor.setPosition(cur); cursor.select(QTextCursor::WordUnderCursor); @@ -167,8 +165,7 @@ void Text::paint(QPainter* painter, const QStyleOptionGraphicsItem* option, QWid QAbstractTextDocumentLayout::PaintContext ctx; QAbstractTextDocumentLayout::Selection sel; - if (hasSelection()) - { + if (hasSelection()) { sel.cursor = QTextCursor(doc); sel.cursor.setPosition(getSelectionStart()); sel.cursor.setPosition(getSelectionEnd(), QTextCursor::KeepAnchor); @@ -197,13 +194,13 @@ qreal Text::getAscent() const return ascent; } -void Text::mousePressEvent(QGraphicsSceneMouseEvent *event) +void Text::mousePressEvent(QGraphicsSceneMouseEvent* event) { if (event->button() == Qt::LeftButton) event->accept(); // grabber } -void Text::mouseReleaseEvent(QGraphicsSceneMouseEvent *event) +void Text::mouseReleaseEvent(QGraphicsSceneMouseEvent* event) { if (!doc) return; @@ -215,7 +212,7 @@ void Text::mouseReleaseEvent(QGraphicsSceneMouseEvent *event) QDesktopServices::openUrl(anchor); } -void Text::hoverMoveEvent(QGraphicsSceneHoverEvent *event) +void Text::hoverMoveEvent(QGraphicsSceneHoverEvent* event) { if (!doc) return; @@ -250,25 +247,20 @@ QString Text::getLinkAt(QPointF scenePos) const void Text::regenerate() { - if (!doc) - { + if (!doc) { doc = DocumentCache::getInstance().pop(); dirty = true; } - if (dirty) - { + if (dirty) { doc->setDefaultFont(defFont); - if (elide) - { + if (elide) { QFontMetrics metrics = QFontMetrics(defFont); QString elidedText = metrics.elidedText(text, Qt::ElideRight, qRound(width)); doc->setPlainText(elidedText); - } - else - { + } else { doc->setDefaultStyleSheet(defStyleSheet); doc->setHtml(text); } @@ -318,7 +310,8 @@ QSizeF Text::idealSize() int Text::cursorFromPos(QPointF scenePos, bool fuzzy) const { if (doc) - return doc->documentLayout()->hitTest(mapFromScene(scenePos), fuzzy ? Qt::FuzzyHit : Qt::ExactHit); + return doc->documentLayout()->hitTest(mapFromScene(scenePos), + fuzzy ? Qt::FuzzyHit : Qt::ExactHit); return -1; } @@ -346,26 +339,22 @@ QString Text::extractSanitizedText(int from, int to) const QString txt; QTextBlock block = doc->firstBlock(); - for (QTextBlock::Iterator itr = block.begin(); itr!=block.end(); ++itr) - { - int pos = itr.fragment().position(); //fragment position -> position of the first character in the fragment + for (QTextBlock::Iterator itr = block.begin(); itr != block.end(); ++itr) { + int pos = + itr.fragment() + .position(); // fragment position -> position of the first character in the fragment - if (itr.fragment().charFormat().isImageFormat()) - { + if (itr.fragment().charFormat().isImageFormat()) { QTextImageFormat imgFmt = itr.fragment().charFormat().toImageFormat(); - QString key = imgFmt.name(); //img key (eg. key::D for :D) + QString key = imgFmt.name(); // img key (eg. key::D for :D) QString rune = key.mid(4); - if (pos >= from && pos < to) - { + if (pos >= from && pos < to) { txt += rune; ++pos; } - } - else - { - for (QChar c : itr.fragment().text()) - { + } else { + for (QChar c : itr.fragment().text()) { if (pos >= from && pos < to) txt += c; @@ -379,10 +368,8 @@ QString Text::extractSanitizedText(int from, int to) const QString Text::extractImgTooltip(int pos) const { - for (QTextBlock::Iterator itr = doc->firstBlock().begin(); itr!=doc->firstBlock().end(); ++itr) - { - if (itr.fragment().contains(pos) && itr.fragment().charFormat().isImageFormat()) - { + for (QTextBlock::Iterator itr = doc->firstBlock().begin(); itr != doc->firstBlock().end(); ++itr) { + if (itr.fragment().contains(pos) && itr.fragment().charFormat().isImageFormat()) { QTextImageFormat imgFmt = itr.fragment().charFormat().toImageFormat(); return imgFmt.toolTip(); } diff --git a/src/chatlog/content/text.h b/src/chatlog/content/text.h index 1176d2ef8..fdfc7618d 100644 --- a/src/chatlog/content/text.h +++ b/src/chatlog/content/text.h @@ -31,7 +31,8 @@ class Text : public ChatLineContent Q_OBJECT public: - Text(const QString& txt = "", const QFont& font = QFont(), bool enableElide = false, const QString& rawText = QString(), const QColor c = Qt::black); + Text(const QString& txt = "", const QFont& font = QFont(), bool enableElide = false, + const QString& rawText = QString(), const QColor c = Qt::black); virtual ~Text(); void setText(const QString& txt); @@ -53,8 +54,8 @@ public: virtual void visibilityChanged(bool keepInMemory) final; virtual qreal getAscent() const final; - virtual void mousePressEvent(QGraphicsSceneMouseEvent *event) final override; - virtual void mouseReleaseEvent(QGraphicsSceneMouseEvent *event) final override; + virtual void mousePressEvent(QGraphicsSceneMouseEvent* event) final override; + virtual void mouseReleaseEvent(QGraphicsSceneMouseEvent* event) final override; void hoverMoveEvent(QGraphicsSceneHoverEvent* event) final override; virtual QString getText() const final; @@ -90,7 +91,6 @@ private: QFont defFont; QString defStyleSheet; QColor color; - }; #endif // TEXT_H diff --git a/src/chatlog/content/timestamp.cpp b/src/chatlog/content/timestamp.cpp index 1a726eedf..6cc422254 100644 --- a/src/chatlog/content/timestamp.cpp +++ b/src/chatlog/content/timestamp.cpp @@ -19,7 +19,7 @@ #include "timestamp.h" -Timestamp::Timestamp(const QDateTime &time, const QString &format, const QFont &font) +Timestamp::Timestamp(const QDateTime& time, const QString& format, const QFont& font) : Text(time.toString(format), font, false, time.toString(format)) { this->time = time; diff --git a/src/chatlog/content/timestamp.h b/src/chatlog/content/timestamp.h index b2ec0ed0b..05a332a2d 100644 --- a/src/chatlog/content/timestamp.h +++ b/src/chatlog/content/timestamp.h @@ -20,8 +20,8 @@ #ifndef TIMESTAMP_H #define TIMESTAMP_H -#include #include "text.h" +#include class Timestamp : public Text { diff --git a/src/chatlog/customtextdocument.cpp b/src/chatlog/customtextdocument.cpp index 5f3fd275b..26adc06e6 100644 --- a/src/chatlog/customtextdocument.cpp +++ b/src/chatlog/customtextdocument.cpp @@ -22,22 +22,22 @@ #include "src/persistence/smileypack.h" #include "src/widget/style.h" -#include #include +#include #include -CustomTextDocument::CustomTextDocument(QObject *parent) +CustomTextDocument::CustomTextDocument(QObject* parent) : QTextDocument(parent) { setUndoRedoEnabled(false); setUseDesignMetrics(false); } -QVariant CustomTextDocument::loadResource(int type, const QUrl &name) +QVariant CustomTextDocument::loadResource(int type, const QUrl& name) { - if (type == QTextDocument::ImageResource && name.scheme() == "key") - { - QSize size = QSize(Settings::getInstance().getEmojiFontPointSize(),Settings::getInstance().getEmojiFontPointSize()); + if (type == QTextDocument::ImageResource && name.scheme() == "key") { + QSize size = QSize(Settings::getInstance().getEmojiFontPointSize(), + Settings::getInstance().getEmojiFontPointSize()); QString fileName = QUrl::fromPercentEncoding(name.toEncoded()).mid(4).toHtmlEscaped(); return SmileyPack::getInstance().getAsIcon(fileName).pixmap(size); diff --git a/src/chatlog/customtextdocument.h b/src/chatlog/customtextdocument.h index b14fcc216..8f2a9f89c 100644 --- a/src/chatlog/customtextdocument.h +++ b/src/chatlog/customtextdocument.h @@ -26,10 +26,10 @@ class CustomTextDocument : public QTextDocument { Q_OBJECT public: - explicit CustomTextDocument(QObject *parent = 0); + explicit CustomTextDocument(QObject* parent = 0); protected: - virtual QVariant loadResource(int type, const QUrl &name); + virtual QVariant loadResource(int type, const QUrl& name); }; #endif // CUSTOMTEXTDOCUMENT_H diff --git a/src/chatlog/documentcache.cpp b/src/chatlog/documentcache.cpp index df5d81981..d5780befb 100644 --- a/src/chatlog/documentcache.cpp +++ b/src/chatlog/documentcache.cpp @@ -34,10 +34,9 @@ QTextDocument* DocumentCache::pop() return documents.pop(); } -void DocumentCache::push(QTextDocument *doc) +void DocumentCache::push(QTextDocument* doc) { - if (doc) - { + if (doc) { doc->clear(); documents.push(doc); } @@ -46,7 +45,7 @@ void DocumentCache::push(QTextDocument *doc) /** * @brief Returns the singleton instance. */ -DocumentCache &DocumentCache::getInstance() +DocumentCache& DocumentCache::getInstance() { static DocumentCache instance; return instance; diff --git a/src/chatlog/pixmapcache.cpp b/src/chatlog/pixmapcache.cpp index ea8c37aed..090ea5b3c 100644 --- a/src/chatlog/pixmapcache.cpp +++ b/src/chatlog/pixmapcache.cpp @@ -19,12 +19,11 @@ #include "pixmapcache.h" -QPixmap PixmapCache::get(const QString &filename, QSize size) +QPixmap PixmapCache::get(const QString& filename, QSize size) { auto itr = cache.find(filename); - if (itr == cache.end()) - { + if (itr == cache.end()) { QIcon icon; icon.addFile(filename); @@ -38,9 +37,8 @@ QPixmap PixmapCache::get(const QString &filename, QSize size) /** * @brief Returns the singleton instance. */ -PixmapCache &PixmapCache::getInstance() +PixmapCache& PixmapCache::getInstance() { static PixmapCache instance; return instance; } - diff --git a/src/chatlog/pixmapcache.h b/src/chatlog/pixmapcache.h index eb22392ec..9de83bb03 100644 --- a/src/chatlog/pixmapcache.h +++ b/src/chatlog/pixmapcache.h @@ -20,9 +20,9 @@ #ifndef ICONCACHE_H #define ICONCACHE_H +#include #include #include -#include class PixmapCache { @@ -31,7 +31,9 @@ public: static PixmapCache& getInstance(); protected: - PixmapCache() {} + PixmapCache() + { + } PixmapCache(PixmapCache&) = delete; PixmapCache& operator=(const PixmapCache&) = delete; diff --git a/src/chatlog/textformatter.cpp b/src/chatlog/textformatter.cpp index 201d9e405..e12fcd3c9 100644 --- a/src/chatlog/textformatter.cpp +++ b/src/chatlog/textformatter.cpp @@ -24,7 +24,8 @@ #include #include -enum TextStyle { +enum TextStyle +{ BOLD = 0, ITALIC, UNDERLINE, @@ -49,31 +50,27 @@ static const QString MULTILINE_CODE = QStringLiteral("(?<=^|[^`])" "(?=$|[^`])"); // Items in vector associated with TextStyle values respectively. Do NOT change this order -static const QVector fontStylePatterns -{ - QStringLiteral("%1"), - QStringLiteral("%1"), - QStringLiteral("%1"), - QStringLiteral("%1"), - QStringLiteral("%1") -}; +static const QVector fontStylePatterns{QStringLiteral("%1"), + QStringLiteral("%1"), + QStringLiteral("%1"), + QStringLiteral("%1"), + QStringLiteral( + "%1")}; // Unfortunately, can't use simple QMap because ordered applying of styles is required -static const QVector> textPatternStyle -{ - { QRegularExpression(COMMON_PATTERN.arg("*", "1")), fontStylePatterns[BOLD] }, - { QRegularExpression(COMMON_PATTERN.arg("/", "1")), fontStylePatterns[ITALIC] }, - { QRegularExpression(COMMON_PATTERN.arg("_", "1")), fontStylePatterns[UNDERLINE] }, - { QRegularExpression(COMMON_PATTERN.arg("~", "1")), fontStylePatterns[STRIKE] }, - { QRegularExpression(COMMON_PATTERN.arg("`", "1")), fontStylePatterns[CODE] }, - { QRegularExpression(COMMON_PATTERN.arg("*", "2")), fontStylePatterns[BOLD] }, - { QRegularExpression(COMMON_PATTERN.arg("/", "2")), fontStylePatterns[ITALIC] }, - { QRegularExpression(COMMON_PATTERN.arg("_", "2")), fontStylePatterns[UNDERLINE] }, - { QRegularExpression(COMMON_PATTERN.arg("~", "2")), fontStylePatterns[STRIKE] }, - { QRegularExpression(MULTILINE_CODE), fontStylePatterns[CODE] } -}; +static const QVector> textPatternStyle{ + {QRegularExpression(COMMON_PATTERN.arg("*", "1")), fontStylePatterns[BOLD]}, + {QRegularExpression(COMMON_PATTERN.arg("/", "1")), fontStylePatterns[ITALIC]}, + {QRegularExpression(COMMON_PATTERN.arg("_", "1")), fontStylePatterns[UNDERLINE]}, + {QRegularExpression(COMMON_PATTERN.arg("~", "1")), fontStylePatterns[STRIKE]}, + {QRegularExpression(COMMON_PATTERN.arg("`", "1")), fontStylePatterns[CODE]}, + {QRegularExpression(COMMON_PATTERN.arg("*", "2")), fontStylePatterns[BOLD]}, + {QRegularExpression(COMMON_PATTERN.arg("/", "2")), fontStylePatterns[ITALIC]}, + {QRegularExpression(COMMON_PATTERN.arg("_", "2")), fontStylePatterns[UNDERLINE]}, + {QRegularExpression(COMMON_PATTERN.arg("~", "2")), fontStylePatterns[STRIKE]}, + {QRegularExpression(MULTILINE_CODE), fontStylePatterns[CODE]}}; -TextFormatter::TextFormatter(const QString &str) +TextFormatter::TextFormatter(const QString& str) : sourceString(str) { } @@ -88,8 +85,7 @@ static int patternSignsCount(const QString& str) QChar escapeSign = str.at(0); int result = 0; int length = str.length(); - while (result < length && str[result] == escapeSign) - { + while (result < length && str[result] == escapeSign) { ++result; } return result; @@ -108,34 +104,29 @@ static bool isTagIntersection(const QString& str) int closingTagCount = 0; QRegularExpressionMatchIterator iter = TAG_PATTERN.globalMatch(str); - while (iter.hasNext()) - { - iter.next().captured()[0] == '/' - ? ++closingTagCount - : ++openingTagCount; + while (iter.hasNext()) { + iter.next().captured()[0] == '/' ? ++closingTagCount : ++openingTagCount; } return openingTagCount != closingTagCount; } /** * @brief Applies styles to the font of text that was passed to the constructor - * @param showFormattingSymbols True, if it is supposed to include formatting symbols into resulting string + * @param showFormattingSymbols True, if it is supposed to include formatting symbols into resulting + * string * @return Source text with styled font */ QString TextFormatter::applyHtmlFontStyling(bool showFormattingSymbols) { QString out = sourceString; - for (QPair pair : textPatternStyle) - { + for (QPair pair : textPatternStyle) { QRegularExpressionMatchIterator matchesIterator = pair.first.globalMatch(out); int insertedTagSymbolsCount = 0; - while (matchesIterator.hasNext()) - { + while (matchesIterator.hasNext()) { QRegularExpressionMatch match = matchesIterator.next(); - if (isTagIntersection(match.captured())) - { + if (isTagIntersection(match.captured())) { continue; } @@ -159,7 +150,8 @@ QString TextFormatter::applyHtmlFontStyling(bool showFormattingSymbols) /** * @brief Applies all styling for the text - * @param showFormattingSymbols True, if it is supposed to include formatting symbols into resulting string + * @param showFormattingSymbols True, if it is supposed to include formatting symbols into resulting + * string * @return Styled string */ QString TextFormatter::applyStyling(bool showFormattingSymbols) diff --git a/src/chatlog/textformatter.h b/src/chatlog/textformatter.h index bed818027..b25ec08de 100644 --- a/src/chatlog/textformatter.h +++ b/src/chatlog/textformatter.h @@ -25,7 +25,6 @@ class TextFormatter { private: - QString sourceString; QString applyHtmlFontStyling(bool showFormattingSymbols); diff --git a/src/core/core.cpp b/src/core/core.cpp index be00452bc..fb22391c3 100644 --- a/src/core/core.cpp +++ b/src/core/core.cpp @@ -19,37 +19,37 @@ */ #include "core.h" -#include "src/nexus.h" -#include "src/core/cstring.h" -#include "src/core/coreav.h" -#include "src/persistence/settings.h" -#include "src/widget/gui.h" -#include "src/persistence/profilelocker.h" -#include "src/net/avatarbroadcaster.h" -#include "src/persistence/profile.h" #include "corefile.h" +#include "src/core/coreav.h" +#include "src/core/cstring.h" +#include "src/net/avatarbroadcaster.h" +#include "src/nexus.h" +#include "src/persistence/profile.h" +#include "src/persistence/profilelocker.h" +#include "src/persistence/settings.h" #include "src/video/camerasource.h" +#include "src/widget/gui.h" #include #include -#include #include -#include +#include #include +#include +#include +#include +#include #include #include #include +#include +#include #include #include #include #include -#include -#include -#include -#include -#include const QString Core::CONFIG_FILE_NAME = "data"; const QString Core::TOX_EXT = ".tox"; @@ -57,8 +57,11 @@ QThread* Core::coreThread{nullptr}; #define MAX_GROUP_MESSAGE_LEN 1024 -Core::Core(QThread *CoreThread, Profile& profile) : - tox(nullptr), av(nullptr), profile(profile), ready{false} +Core::Core(QThread* CoreThread, Profile& profile) + : tox(nullptr) + , av(nullptr) + , profile(profile) + , ready{false} { coreThread = CoreThread; @@ -66,18 +69,15 @@ Core::Core(QThread *CoreThread, Profile& profile) : toxTimer->setSingleShot(true); connect(toxTimer, &QTimer::timeout, this, &Core::process); connect(&Settings::getInstance(), &Settings::dhtServerListChanged, this, &Core::process); - } void Core::deadifyTox() { - if (av) - { + if (av) { delete av; av = nullptr; } - if (tox) - { + if (tox) { tox_kill(tox); tox = nullptr; } @@ -85,8 +85,7 @@ void Core::deadifyTox() Core::~Core() { - if (coreThread->isRunning()) - { + if (coreThread->isRunning()) { if (QThread::currentThread() == coreThread) killTimers(false); else @@ -94,10 +93,8 @@ Core::~Core() Q_ARG(bool, false)); } coreThread->exit(0); - if (QThread::currentThread() != coreThread) - { - while (coreThread->isRunning()) - { + if (QThread::currentThread() != coreThread) { + while (coreThread->isRunning()) { qApp->processEvents(); coreThread->wait(500); } @@ -114,19 +111,20 @@ Core* Core::getInstance() return Nexus::getCore(); } -const CoreAV *Core::getAv() const +const CoreAV* Core::getAv() const { return av; } -CoreAV *Core::getAv() +CoreAV* Core::getAv() { return av; } void Core::makeTox(QByteArray savedata) { - // IPv6 needed for LAN discovery, but can crash some weird routers. On by default, can be disabled in options. + // IPv6 needed for LAN discovery, but can crash some weird routers. On by default, can be + // disabled in options. bool enableIPv6 = Settings::getInstance().getEnableIPv6(); bool forceTCP = Settings::getInstance().getForceTCP(); Settings::ProxyType proxyType = Settings::getInstance().getProxyType(); @@ -150,18 +148,15 @@ void Core::makeTox(QByteArray savedata) toxOptions.proxy_host = nullptr; toxOptions.proxy_port = 0; - toxOptions.savedata_type = (!savedata.isNull() ? TOX_SAVEDATA_TYPE_TOX_SAVE : TOX_SAVEDATA_TYPE_NONE); + toxOptions.savedata_type = + (!savedata.isNull() ? TOX_SAVEDATA_TYPE_TOX_SAVE : TOX_SAVEDATA_TYPE_NONE); toxOptions.savedata_data = (uint8_t*)savedata.data(); toxOptions.savedata_length = savedata.size(); - if (proxyType != Settings::ProxyType::ptNone) - { - if (proxyAddr.length() > 255) - { + if (proxyType != Settings::ProxyType::ptNone) { + if (proxyAddr.length() > 255) { qWarning() << "proxy address" << proxyAddr << "is too long"; - } - else if (proxyAddr != "" && proxyPort > 0) - { + } else if (proxyAddr != "" && proxyPort > 0) { qDebug() << "using proxy" << proxyAddr << ":" << proxyPort; // protection against changings in TOX_PROXY_TYPE enum if (proxyType == Settings::ProxyType::ptSOCKS5) @@ -177,59 +172,56 @@ void Core::makeTox(QByteArray savedata) TOX_ERR_NEW tox_err; tox = tox_new(&toxOptions, &tox_err); - switch (tox_err) - { - case TOX_ERR_NEW_OK: - break; - case TOX_ERR_NEW_LOAD_BAD_FORMAT: - qWarning() << "failed to parse Tox save data"; - break; - case TOX_ERR_NEW_PORT_ALLOC: - if (enableIPv6) - { - toxOptions.ipv6_enabled = false; - tox = tox_new(&toxOptions, &tox_err); - if (tox_err == TOX_ERR_NEW_OK) - { - qWarning() << "Core failed to start with IPv6, falling back to IPv4. LAN discovery may not work properly."; - break; - } + switch (tox_err) { + case TOX_ERR_NEW_OK: + break; + case TOX_ERR_NEW_LOAD_BAD_FORMAT: + qWarning() << "failed to parse Tox save data"; + break; + case TOX_ERR_NEW_PORT_ALLOC: + if (enableIPv6) { + toxOptions.ipv6_enabled = false; + tox = tox_new(&toxOptions, &tox_err); + if (tox_err == TOX_ERR_NEW_OK) { + qWarning() << "Core failed to start with IPv6, falling back to IPv4. LAN discovery " + "may not work properly."; + break; } + } - qCritical() << "can't to bind the port"; - emit failedToStart(); - return; - case TOX_ERR_NEW_PROXY_BAD_HOST: - case TOX_ERR_NEW_PROXY_BAD_PORT: - case TOX_ERR_NEW_PROXY_BAD_TYPE: - qCritical() << "bad proxy, error code:" << tox_err; - emit badProxy(); - return; - case TOX_ERR_NEW_PROXY_NOT_FOUND: - qCritical() << "proxy not found"; - emit badProxy(); - return; - case TOX_ERR_NEW_LOAD_ENCRYPTED: - qCritical() << "attempted to load encrypted Tox save data"; - emit failedToStart(); - return; - case TOX_ERR_NEW_MALLOC: - qCritical() << "memory allocation failed"; - emit failedToStart(); - return; - case TOX_ERR_NEW_NULL: - qCritical() << "a parameter was null"; - emit failedToStart(); - return; - default: - qCritical() << "Tox core failed to start, unknown error code:" << tox_err; - emit failedToStart(); - return; + qCritical() << "can't to bind the port"; + emit failedToStart(); + return; + case TOX_ERR_NEW_PROXY_BAD_HOST: + case TOX_ERR_NEW_PROXY_BAD_PORT: + case TOX_ERR_NEW_PROXY_BAD_TYPE: + qCritical() << "bad proxy, error code:" << tox_err; + emit badProxy(); + return; + case TOX_ERR_NEW_PROXY_NOT_FOUND: + qCritical() << "proxy not found"; + emit badProxy(); + return; + case TOX_ERR_NEW_LOAD_ENCRYPTED: + qCritical() << "attempted to load encrypted Tox save data"; + emit failedToStart(); + return; + case TOX_ERR_NEW_MALLOC: + qCritical() << "memory allocation failed"; + emit failedToStart(); + return; + case TOX_ERR_NEW_NULL: + qCritical() << "a parameter was null"; + emit failedToStart(); + return; + default: + qCritical() << "Tox core failed to start, unknown error code:" << tox_err; + emit failedToStart(); + return; } av = new CoreAV(tox); - if (av->getToxAv() == nullptr) - { + if (av->getToxAv() == nullptr) { qCritical() << "Toxav core failed to start"; emit failedToStart(); return; @@ -242,19 +234,15 @@ void Core::makeTox(QByteArray savedata) void Core::start() { bool isNewProfile = profile.isNewProfile(); - if (isNewProfile) - { + if (isNewProfile) { qDebug() << "Creating a new profile"; makeTox(QByteArray()); setStatusMessage(tr("Toxing on qTox")); setUsername(profile.getName()); - } - else - { + } else { qDebug() << "Loading user profile"; QByteArray savedata = profile.loadToxSave(); - if (savedata.isEmpty()) - { + if (savedata.isEmpty()) { emit failedToStart(); return; } @@ -263,8 +251,7 @@ void Core::start() qsrand(time(nullptr)); - if (!tox) - { + if (!tox) { ready = true; GUI::setEnabled(true); return; @@ -280,7 +267,7 @@ void Core::start() emit statusMessageSet(msg); ToxId id = getSelfId(); - if (id.isValid()) // TODO: probably useless check, comes basically directly from toxcore + if (id.isValid()) // TODO: probably useless check, comes basically directly from toxcore emit idSet(id); loadFriends(); @@ -303,25 +290,21 @@ void Core::start() tox_callback_file_recv_control(tox, CoreFile::onFileControlCallback); QPixmap pic = profile.loadAvatar(); - if (!pic.isNull() && !pic.size().isEmpty()) - { + if (!pic.isNull() && !pic.size().isEmpty()) { QByteArray data; QBuffer buffer(&data); buffer.open(QIODevice::WriteOnly); pic.save(&buffer, "PNG"); buffer.close(); setAvatar(data); - } - else - { + } else { qDebug() << "Self avatar not found, will broadcast empty avatar to friends"; setAvatar({}); } ready = true; - if (isNewProfile) - { + if (isNewProfile) { profile.saveToxSave(); } @@ -346,8 +329,7 @@ void Core::start() */ void Core::process() { - if (!isReady()) - { + if (!isReady()) { av->stop(); return; } @@ -356,18 +338,15 @@ void Core::process() tox_iterate(tox, getInstance()); #ifdef DEBUG - //we want to see the debug messages immediately + // we want to see the debug messages immediately fflush(stdout); #endif - if (checkConnection()) - { + if (checkConnection()) { tolerance = CORE_DISCONNECT_TOLERANCE; - } - else if (!(--tolerance)) - { + } else if (!(--tolerance)) { bootstrapDht(); - tolerance = 3*CORE_DISCONNECT_TOLERANCE; + tolerance = 3 * CORE_DISCONNECT_TOLERANCE; } unsigned sleeptime = qMin(tox_iteration_interval(tox), CoreFile::corefileIterationInterval()); @@ -377,24 +356,21 @@ void Core::process() bool Core::checkConnection() { static bool isConnected = false; - //static int count = 0; + // static int count = 0; bool toxConnected = tox_self_get_connection_status(tox) != TOX_CONNECTION_NONE; - if (toxConnected && !isConnected) - { + if (toxConnected && !isConnected) { qDebug() << "Connected to the DHT"; emit connected(); isConnected = true; - //if (count) qDebug() << "disconnect count:" << count; - //count = 0; - } - else if (!toxConnected && isConnected) - { + // if (count) qDebug() << "disconnect count:" << count; + // count = 0; + } else if (!toxConnected && isConnected) { qDebug() << "Disconnected from the DHT"; emit disconnected(); isConnected = false; - //count++; - } //else if (!toxConnected) ++count; + // count++; + } // else if (!toxConnected) ++count; return isConnected; } @@ -407,19 +383,19 @@ void Core::bootstrapDht() QList dhtServerList = s.getDhtServerList(); int listSize = dhtServerList.size(); - if (listSize == 0) - { + if (listSize == 0) { qWarning() << "no bootstrap list?!?"; return; } static int j = qrand() % listSize; - int i=0; - while (i < 2) // i think the more we bootstrap, the more we jitter because the more we overwrite nodes + int i = 0; + while (i < 2) // i think the more we bootstrap, the more we jitter because the more we overwrite + // nodes { const DhtServer& dhtServer = dhtServerList[j % listSize]; - qDebug() << "Connecting to "+QString(dhtServer.address.toLatin1().data()) - +':'+QString().setNum(dhtServer.port)+" ("+dhtServer.name+')'; + qDebug() << "Connecting to " + QString(dhtServer.address.toLatin1().data()) + ':' + + QString().setNum(dhtServer.port) + " (" + dhtServer.name + ')'; QByteArray address = dhtServer.address.toLatin1(); // TODO: constucting the pk via ToxId is a workaround @@ -427,14 +403,12 @@ void Core::bootstrapDht() const uint8_t* pkPtr = reinterpret_cast(pk.getBytes()); - if (!tox_bootstrap(tox, address.constData(), dhtServer.port, pkPtr, nullptr)) - { - qDebug() << "Error bootstrapping from "+dhtServer.name; + if (!tox_bootstrap(tox, address.constData(), dhtServer.port, pkPtr, nullptr)) { + qDebug() << "Error bootstrapping from " + dhtServer.name; } - if (!tox_add_tcp_relay(tox, address.constData(), dhtServer.port, pkPtr, nullptr)) - { - qDebug() << "Error adding TCP relay from "+dhtServer.name; + if (!tox_add_tcp_relay(tox, address.constData(), dhtServer.port, pkPtr, nullptr)) { + qDebug() << "Error adding TCP relay from " + dhtServer.name; } ++j; @@ -442,86 +416,85 @@ void Core::bootstrapDht() } } -void Core::onFriendRequest(Tox*/* tox*/, const uint8_t* cFriendPk, - const uint8_t* cMessage, size_t cMessageSize, void* core) +void Core::onFriendRequest(Tox* /* tox*/, const uint8_t* cFriendPk, const uint8_t* cMessage, + size_t cMessageSize, void* core) { ToxPk friendPk(cFriendPk); - emit static_cast(core)->friendRequestReceived(friendPk, CString::toString(cMessage, cMessageSize)); + emit static_cast(core)->friendRequestReceived(friendPk, + CString::toString(cMessage, cMessageSize)); } -void Core::onFriendMessage(Tox*/* tox*/, uint32_t friendId, TOX_MESSAGE_TYPE type, +void Core::onFriendMessage(Tox* /* tox*/, uint32_t friendId, TOX_MESSAGE_TYPE type, const uint8_t* cMessage, size_t cMessageSize, void* core) { bool isAction = (type == TOX_MESSAGE_TYPE_ACTION); - emit static_cast(core)->friendMessageReceived(friendId,CString::toString(cMessage, cMessageSize), isAction); + emit static_cast(core)->friendMessageReceived(friendId, + CString::toString(cMessage, cMessageSize), + isAction); } -void Core::onFriendNameChange(Tox*/* tox*/, uint32_t friendId, - const uint8_t* cName, size_t cNameSize, void* core) +void Core::onFriendNameChange(Tox* /* tox*/, uint32_t friendId, const uint8_t* cName, + size_t cNameSize, void* core) { emit static_cast(core)->friendUsernameChanged(friendId, CString::toString(cName, cNameSize)); } -void Core::onFriendTypingChange(Tox*/* tox*/, uint32_t friendId, bool isTyping, void *core) +void Core::onFriendTypingChange(Tox* /* tox*/, uint32_t friendId, bool isTyping, void* core) { emit static_cast(core)->friendTypingChanged(friendId, isTyping ? true : false); } -void Core::onStatusMessageChanged(Tox*/* tox*/, uint32_t friendId, const uint8_t* cMessage, +void Core::onStatusMessageChanged(Tox* /* tox*/, uint32_t friendId, const uint8_t* cMessage, size_t cMessageSize, void* core) { - emit static_cast(core)->friendStatusMessageChanged(friendId, CString::toString(cMessage, cMessageSize)); + emit static_cast(core)->friendStatusMessageChanged(friendId, + CString::toString(cMessage, cMessageSize)); } -void Core::onUserStatusChanged(Tox*/* tox*/, uint32_t friendId, TOX_USER_STATUS userstatus, void* core) +void Core::onUserStatusChanged(Tox* /* tox*/, uint32_t friendId, TOX_USER_STATUS userstatus, void* core) { Status status; - switch (userstatus) - { - case TOX_USER_STATUS_NONE: - status = Status::Online; - break; - case TOX_USER_STATUS_AWAY: - status = Status::Away; - break; - case TOX_USER_STATUS_BUSY: - status = Status::Busy; - break; - default: - status = Status::Online; - break; + switch (userstatus) { + case TOX_USER_STATUS_NONE: + status = Status::Online; + break; + case TOX_USER_STATUS_AWAY: + status = Status::Away; + break; + case TOX_USER_STATUS_BUSY: + status = Status::Busy; + break; + default: + status = Status::Online; + break; } emit static_cast(core)->friendStatusChanged(friendId, status); } -void Core::onConnectionStatusChanged(Tox*/* tox*/, uint32_t friendId, TOX_CONNECTION status, void* core) +void Core::onConnectionStatusChanged(Tox* /* tox*/, uint32_t friendId, TOX_CONNECTION status, void* core) { Status friendStatus = status != TOX_CONNECTION_NONE ? Status::Online : Status::Offline; emit static_cast(core)->friendStatusChanged(friendId, friendStatus); if (friendStatus == Status::Offline) static_cast(core)->checkLastOnline(friendId); - CoreFile::onConnectionStatusChanged(static_cast(core), friendId, friendStatus != Status::Offline); + CoreFile::onConnectionStatusChanged(static_cast(core), friendId, + friendStatus != Status::Offline); } -void Core::onGroupInvite(Tox*, uint32_t friendId, TOX_CONFERENCE_TYPE type, - const uint8_t* data, size_t length, void* vCore) +void Core::onGroupInvite(Tox*, uint32_t friendId, TOX_CONFERENCE_TYPE type, const uint8_t* data, + size_t length, void* vCore) { Core* core = static_cast(vCore); QByteArray pk((char*)data, length); - if (type == TOX_CONFERENCE_TYPE_TEXT) - { + if (type == TOX_CONFERENCE_TYPE_TEXT) { qDebug() << QString("Text group invite by %1").arg(friendId); emit core->groupInviteReceived(friendId, type, pk); - } - else if (type == TOX_CONFERENCE_TYPE_AV) - { + } else if (type == TOX_CONFERENCE_TYPE_AV) { qDebug() << QString("AV group invite by %1").arg(friendId); emit core->groupInviteReceived(friendId, type, pk); - } - else - { - qWarning() << "Group invite with unknown type "<(core)->getAv(); - if((change == TOX_CONFERENCE_STATE_CHANGE_PEER_EXIT) && (coreAv->isGroupAvEnabled(groupId))) { + if ((change == TOX_CONFERENCE_STATE_CHANGE_PEER_EXIT) && (coreAv->isGroupAvEnabled(groupId))) { CoreAV::invalidateGroupCallPeerSource(groupId, peerId); } qDebug() << QString("Group namelist change %1:%2 %3").arg(groupId).arg(peerId).arg(change); emit static_cast(core)->groupNamelistChanged(groupId, peerId, change); } -void Core::onGroupTitleChange(Tox*, uint32_t groupId, uint32_t peerId, - const uint8_t* cTitle, size_t length, void* vCore) +void Core::onGroupTitleChange(Tox*, uint32_t groupId, uint32_t peerId, const uint8_t* cTitle, + size_t length, void* vCore) { Core* core = static_cast(vCore); QString author = core->getGroupPeerName(groupId, peerId); @@ -563,12 +536,9 @@ void Core::acceptFriendRequest(const ToxPk& friendPk) { // TODO: error handling uint32_t friendId = tox_friend_add_norequest(tox, friendPk.getBytes(), nullptr); - if (friendId == std::numeric_limits::max()) - { + if (friendId == std::numeric_limits::max()) { emit failedToAddFriend(friendPk); - } - else - { + } else { profile.saveToxSave(); emit friendAdded(friendId, friendPk); emit friendshipChanged(friendId); @@ -579,39 +549,23 @@ void Core::requestFriendship(const ToxId& friendAddress, const QString& message) { ToxPk friendPk = friendAddress.getPublicKey(); - if (!friendAddress.isValid()) - { - emit failedToAddFriend(friendPk, - tr("Invalid Tox ID")); - } - else if (message.isEmpty()) - { - emit failedToAddFriend(friendPk, - tr("You need to write a message with your request")); - } - else if (message.size() > TOX_MAX_FRIEND_REQUEST_LENGTH) - { - emit failedToAddFriend(friendPk, - tr("Your message is too long!")); - } - else if (hasFriendWithPublicKey(friendPk)) - { - emit failedToAddFriend(friendPk, - tr("Friend is already added")); - } - else - { + if (!friendAddress.isValid()) { + emit failedToAddFriend(friendPk, tr("Invalid Tox ID")); + } else if (message.isEmpty()) { + emit failedToAddFriend(friendPk, tr("You need to write a message with your request")); + } else if (message.size() > TOX_MAX_FRIEND_REQUEST_LENGTH) { + emit failedToAddFriend(friendPk, tr("Your message is too long!")); + } else if (hasFriendWithPublicKey(friendPk)) { + emit failedToAddFriend(friendPk, tr("Friend is already added")); + } else { CString cMessage(message); - uint32_t friendId = tox_friend_add(tox, friendAddress.getBytes(), - cMessage.data(), cMessage.size(), nullptr); - if (friendId == std::numeric_limits::max()) - { + uint32_t friendId = + tox_friend_add(tox, friendAddress.getBytes(), cMessage.data(), cMessage.size(), nullptr); + if (friendId == std::numeric_limits::max()) { qDebug() << "Failed to request friendship"; emit failedToAddFriend(friendPk); - } - else - { + } else { qDebug() << "Requested friendship of " << friendId; // Update our friendAddresses Settings::getInstance().updateFriendAddress(friendAddress.toString()); @@ -622,14 +576,10 @@ void Core::requestFriendship(const ToxId& friendAddress, const QString& message) inviteStr = tr("/me offers friendship, \"%1\"").arg(message); Profile* profile = Nexus::getProfile(); - if (profile->isHistoryEnabled()) - { - profile->getHistory()->addNewMessage(friendAddress.toString(), - inviteStr, + if (profile->isHistoryEnabled()) { + profile->getHistory()->addNewMessage(friendAddress.toString(), inviteStr, getSelfId().getPublicKey().toString(), - QDateTime::currentDateTime(), - true, - QString()); + QDateTime::currentDateTime(), true, QString()); } // TODO: end @@ -644,18 +594,18 @@ int Core::sendMessage(uint32_t friendId, const QString& message) { QMutexLocker ml(&messageSendMutex); CString cMessage(message); - int receipt = tox_friend_send_message(tox, friendId, TOX_MESSAGE_TYPE_NORMAL, - cMessage.data(), cMessage.size(), nullptr); + int receipt = tox_friend_send_message(tox, friendId, TOX_MESSAGE_TYPE_NORMAL, cMessage.data(), + cMessage.size(), nullptr); emit messageSentResult(friendId, message, receipt); return receipt; } -int Core::sendAction(uint32_t friendId, const QString &action) +int Core::sendAction(uint32_t friendId, const QString& action) { QMutexLocker ml(&messageSendMutex); CString cMessage(action); - int receipt = tox_friend_send_message(tox, friendId, TOX_MESSAGE_TYPE_ACTION, - cMessage.data(), cMessage.size(), nullptr); + int receipt = tox_friend_send_message(tox, friendId, TOX_MESSAGE_TYPE_ACTION, cMessage.data(), + cMessage.size(), nullptr); emit messageSentResult(friendId, action, receipt); return receipt; } @@ -671,20 +621,17 @@ void Core::sendGroupMessageWithType(int groupId, const QString& message, TOX_MES { QList cMessages = splitMessage(message, MAX_GROUP_MESSAGE_LEN); - for (auto &cMsg :cMessages) - { + for (auto& cMsg : cMessages) { TOX_ERR_CONFERENCE_SEND_MESSAGE error; - bool success = tox_conference_send_message(tox, groupId, type, - cMsg.data(), cMsg.size(), &error); + bool success = + tox_conference_send_message(tox, groupId, type, cMsg.data(), cMsg.size(), &error); - if (success && error == TOX_ERR_CONFERENCE_SEND_MESSAGE_OK) - { + if (success && error == TOX_ERR_CONFERENCE_SEND_MESSAGE_OK) { return; } qCritical() << "Fail of tox_conference_send_message"; - switch (error) - { + switch (error) { case TOX_ERR_CONFERENCE_SEND_MESSAGE_CONFERENCE_NOT_FOUND: qCritical() << "Conference not found"; return; @@ -718,18 +665,15 @@ void Core::changeGroupTitle(int groupId, const QString& title) { CString cTitle(title); TOX_ERR_CONFERENCE_TITLE error; - bool success = tox_conference_set_title(tox, groupId, cTitle.data(), - cTitle.size(), &error); + bool success = tox_conference_set_title(tox, groupId, cTitle.data(), cTitle.size(), &error); - if (success && error == TOX_ERR_CONFERENCE_TITLE_OK) - { + if (success && error == TOX_ERR_CONFERENCE_TITLE_OK) { emit groupTitleChanged(groupId, getUsername(), title); return; } qCritical() << "Fail of tox_conference_set_title"; - switch (error) - { + switch (error) { case TOX_ERR_CONFERENCE_TITLE_CONFERENCE_NOT_FOUND: qCritical() << "Conference not found"; break; @@ -789,8 +733,7 @@ void Core::removeFriend(uint32_t friendId, bool fake) if (!isReady() || fake) return; - if (!tox_friend_delete(tox, friendId, nullptr)) - { + if (!tox_friend_delete(tox, friendId, nullptr)) { emit failedToRemoveFriend(friendId); return; } @@ -807,15 +750,13 @@ void Core::removeGroup(int groupId, bool fake) TOX_ERR_CONFERENCE_DELETE error; bool success = tox_conference_delete(tox, groupId, &error); - if (success && error == TOX_ERR_CONFERENCE_DELETE_OK) - { + if (success && error == TOX_ERR_CONFERENCE_DELETE_OK) { av->leaveGroupCall(groupId); return; } qCritical() << "Fail of tox_conference_delete"; - switch (error) - { + switch (error) { case TOX_ERR_CONFERENCE_DELETE_CONFERENCE_NOT_FOUND: qCritical() << "Conference not found"; break; @@ -847,8 +788,7 @@ void Core::setUsername(const QString& username) CString cUsername(username); - if (!tox_self_set_name(tox, cUsername.data(), cUsername.size(), nullptr)) - { + if (!tox_self_set_name(tox, cUsername.data(), cUsername.size(), nullptr)) { emit failedToSetUsername(username); return; } @@ -860,15 +800,12 @@ void Core::setUsername(const QString& username) void Core::setAvatar(const QByteArray& data) { - if (!data.isEmpty()) - { + if (!data.isEmpty()) { QPixmap pic; pic.loadFromData(data); profile.saveAvatar(data, getSelfId().getPublicKey().toString()); emit selfAvatarChanged(pic); - } - else - { + } else { emit selfAvatarChanged(QPixmap(":/img/contact_dark.svg")); } @@ -937,8 +874,7 @@ void Core::setStatusMessage(const QString& message) CString cMessage(message); - if (!tox_self_set_status_message(tox, cMessage.data(), cMessage.size(), nullptr)) - { + if (!tox_self_set_status_message(tox, cMessage.data(), cMessage.size(), nullptr)) { emit failedToSetStatusMessage(message); return; } @@ -951,20 +887,19 @@ void Core::setStatusMessage(const QString& message) void Core::setStatus(Status status) { TOX_USER_STATUS userstatus; - switch (status) - { - case Status::Online: - userstatus = TOX_USER_STATUS_NONE; - break; - case Status::Away: - userstatus = TOX_USER_STATUS_AWAY; - break; - case Status::Busy: - userstatus = TOX_USER_STATUS_BUSY; - break; - default: - return; - break; + switch (status) { + case Status::Online: + userstatus = TOX_USER_STATUS_NONE; + break; + case Status::Away: + userstatus = TOX_USER_STATUS_AWAY; + break; + case Status::Busy: + userstatus = TOX_USER_STATUS_BUSY; + break; + default: + return; + break; } tox_self_set_status(tox, userstatus); @@ -984,7 +919,7 @@ QString Core::sanitize(QString name) name[0] = '_'; if (name.endsWith('.')) - name[name.length()-1] = '_'; + name[name.length() - 1] = '_'; return name; } @@ -1004,47 +939,43 @@ QByteArray Core::getToxSaveData() void Core::loadFriends() { const uint32_t friendCount = tox_self_get_friend_list_size(tox); - if (friendCount > 0) - { + if (friendCount > 0) { // assuming there are not that many friends to fill up the whole stack - uint32_t *ids = new uint32_t[friendCount]; + uint32_t* ids = new uint32_t[friendCount]; tox_self_get_friend_list(tox, ids); uint8_t friendPk[TOX_PUBLIC_KEY_SIZE] = {0x00}; - for (int32_t i = 0; i < static_cast(friendCount); ++i) - { - if (tox_friend_get_public_key(tox, ids[i], friendPk, nullptr)) - { + for (int32_t i = 0; i < static_cast(friendCount); ++i) { + if (tox_friend_get_public_key(tox, ids[i], friendPk, nullptr)) { emit friendAdded(ids[i], ToxPk(friendPk)); const size_t nameSize = tox_friend_get_name_size(tox, ids[i], nullptr); - if (nameSize && nameSize != SIZE_MAX) - { + if (nameSize && nameSize != SIZE_MAX) { uint8_t* name = new uint8_t[nameSize]; if (tox_friend_get_name(tox, ids[i], name, nullptr)) emit friendUsernameChanged(ids[i], CString::toString(name, nameSize)); delete[] name; } - const size_t statusMessageSize = tox_friend_get_status_message_size(tox, ids[i], nullptr); - if (statusMessageSize != SIZE_MAX) - { + const size_t statusMessageSize = + tox_friend_get_status_message_size(tox, ids[i], nullptr); + if (statusMessageSize != SIZE_MAX) { uint8_t* statusMessage = new uint8_t[statusMessageSize]; - if (tox_friend_get_status_message(tox, ids[i], statusMessage, nullptr)) - { - emit friendStatusMessageChanged(ids[i], CString::toString(statusMessage, statusMessageSize)); + if (tox_friend_get_status_message(tox, ids[i], statusMessage, nullptr)) { + emit friendStatusMessageChanged(ids[i], CString::toString(statusMessage, + statusMessageSize)); } delete[] statusMessage; } checkLastOnline(ids[i]); } - } delete[] ids; } } -void Core::checkLastOnline(uint32_t friendId) { +void Core::checkLastOnline(uint32_t friendId) +{ const uint64_t lastOnline = tox_friend_get_last_online(tox, friendId, nullptr); if (lastOnline != std::numeric_limits::max()) emit friendLastSeenChanged(friendId, QDateTime::fromTime_t(lastOnline)); @@ -1068,8 +999,7 @@ QVector Core::getFriendList() const */ bool Core::parsePeerQueryError(TOX_ERR_CONFERENCE_PEER_QUERY error) const { - switch (error) - { + switch (error) { case TOX_ERR_CONFERENCE_PEER_QUERY_OK: return true; case TOX_ERR_CONFERENCE_PEER_QUERY_CONFERENCE_NOT_FOUND: @@ -1113,8 +1043,7 @@ QString Core::getGroupPeerName(int groupId, int peerId) const return QString{}; bool success = tox_conference_peer_get_name(tox, groupId, peerId, nameArray, &error); - if (!parsePeerQueryError(error) || !success) - { + if (!parsePeerQueryError(error) || !success) { qWarning() << "getGroupPeerName: Unknown error"; return QString{}; } @@ -1130,8 +1059,7 @@ ToxPk Core::getGroupPeerPk(int groupId, int peerId) const uint8_t friendPk[TOX_PUBLIC_KEY_SIZE] = {0x00}; TOX_ERR_CONFERENCE_PEER_QUERY error; bool success = tox_conference_peer_get_public_key(tox, groupId, peerId, friendPk, &error); - if (!parsePeerQueryError(error) || !success) - { + if (!parsePeerQueryError(error) || !success) { qWarning() << "getGroupPeerToxId: Unknown error"; return ToxPk(); } @@ -1144,45 +1072,38 @@ ToxPk Core::getGroupPeerPk(int groupId, int peerId) const */ QList Core::getGroupPeerNames(int groupId) const { - if (!tox) - { + if (!tox) { qWarning() << "Can't get group peer names, tox is null"; return {}; } uint32_t nPeers = getGroupNumberPeers(groupId); - if (nPeers == std::numeric_limits::max()) - { + if (nPeers == std::numeric_limits::max()) { qWarning() << "getGroupPeerNames: Unable to get number of peers"; return {}; } // TODO: Change to std::vector - std::unique_ptr namesArray{ - new uint8_t[nPeers][TOX_MAX_NAME_LENGTH]}; + std::unique_ptr namesArray{new uint8_t[nPeers][TOX_MAX_NAME_LENGTH]}; std::unique_ptr lengths{new uint16_t[nPeers]}; TOX_ERR_CONFERENCE_PEER_QUERY error; uint32_t count = tox_conference_peer_count(tox, groupId, &error); - if (!parsePeerQueryError(error)) - { + if (!parsePeerQueryError(error)) { return {}; } - if (count != nPeers) - { + if (count != nPeers) { qWarning() << "getGroupPeerNames: Unexpected peer count"; return {}; } QList names; - for (uint32_t i = 0; i < nPeers; ++i) - { + for (uint32_t i = 0; i < nPeers; ++i) { lengths[i] = tox_conference_peer_get_name_size(tox, groupId, i, &error); bool ok = tox_conference_peer_get_name(tox, groupId, i, namesArray[i], &error); - if (parsePeerQueryError(error) && ok) - { + if (parsePeerQueryError(error) && ok) { names.push_back(CString::toString(namesArray[i], lengths[i])); } } @@ -1197,8 +1118,7 @@ QList Core::getGroupPeerNames(int groupId) const */ bool Core::parseConferenceJoinError(TOX_ERR_CONFERENCE_JOIN error) const { - switch (error) - { + switch (error) { case TOX_ERR_CONFERENCE_JOIN_OK: return true; case TOX_ERR_CONFERENCE_JOIN_DUPLICATE: @@ -1236,26 +1156,21 @@ bool Core::parseConferenceJoinError(TOX_ERR_CONFERENCE_JOIN error) const uint32_t Core::joinGroupchat(int32_t friendnumber, uint8_t type, const uint8_t* friend_group_public_key, uint16_t length) const { - if (type == TOX_CONFERENCE_TYPE_TEXT) - { + if (type == TOX_CONFERENCE_TYPE_TEXT) { qDebug() << QString("Trying to join text groupchat invite sent by friend %1").arg(friendnumber); TOX_ERR_CONFERENCE_JOIN error; - uint32_t groupId = tox_conference_join(tox, friendnumber, friend_group_public_key, length, &error); + uint32_t groupId = + tox_conference_join(tox, friendnumber, friend_group_public_key, length, &error); if (parseConferenceJoinError(error)) return groupId; else return std::numeric_limits::max(); - } - else if (type == TOX_CONFERENCE_TYPE_AV) - { + } else if (type == TOX_CONFERENCE_TYPE_AV) { qDebug() << QString("Trying to join AV groupchat invite sent by friend %1").arg(friendnumber); return toxav_join_av_groupchat(tox, friendnumber, friend_group_public_key, length, - CoreAV::groupCallCallback, - const_cast(this)); - } - else - { - qWarning() << "joinGroupchat: Unknown groupchat type "<(this)); + } else { + qWarning() << "joinGroupchat: Unknown groupchat type " << type; return std::numeric_limits::max(); } } @@ -1268,8 +1183,7 @@ void Core::quitGroupChat(int groupId) const TOX_ERR_CONFERENCE_DELETE error; tox_conference_delete(tox, groupId, &error); - switch (error) - { + switch (error) { case TOX_ERR_CONFERENCE_DELETE_OK: return; case TOX_ERR_CONFERENCE_DELETE_CONFERENCE_NOT_FOUND: @@ -1285,8 +1199,7 @@ void Core::groupInviteFriend(uint32_t friendId, int groupId) TOX_ERR_CONFERENCE_INVITE error; tox_conference_invite(tox, friendId, groupId, &error); - switch (error) - { + switch (error) { case TOX_ERR_CONFERENCE_INVITE_OK: break; case TOX_ERR_CONFERENCE_INVITE_CONFERENCE_NOT_FOUND: @@ -1302,13 +1215,11 @@ void Core::groupInviteFriend(uint32_t friendId, int groupId) int Core::createGroup(uint8_t type) { - if (type == TOX_CONFERENCE_TYPE_TEXT) - { + if (type == TOX_CONFERENCE_TYPE_TEXT) { TOX_ERR_CONFERENCE_NEW error; uint32_t groupId = tox_conference_new(tox, &error); - switch (error) - { + switch (error) { case TOX_ERR_CONFERENCE_NEW_OK: emit emptyGroupCreated(groupId); return groupId; @@ -1318,16 +1229,12 @@ int Core::createGroup(uint8_t type) default: return std::numeric_limits::max(); } - } - else if (type == TOX_CONFERENCE_TYPE_AV) - { + } else if (type == TOX_CONFERENCE_TYPE_AV) { uint32_t groupId = toxav_add_av_groupchat(tox, CoreAV::groupCallCallback, this); emit emptyGroupCreated(groupId); return groupId; - } - else - { - qWarning() << "createGroup: Unknown type "<::max(); } @@ -1364,8 +1270,7 @@ bool Core::hasFriendWithPublicKey(const ToxPk &publicKey) const ToxPk Core::getFriendPublicKey(uint32_t friendNumber) const { uint8_t rawid[TOX_PUBLIC_KEY_SIZE]; - if (!tox_friend_get_public_key(tox, friendNumber, rawid, nullptr)) - { + if (!tox_friend_get_public_key(tox, friendNumber, rawid, nullptr)) { qWarning() << "getFriendPublicKey: Getting public key failed"; return ToxPk(); } @@ -1379,9 +1284,8 @@ ToxPk Core::getFriendPublicKey(uint32_t friendNumber) const QString Core::getFriendUsername(uint32_t friendnumber) const { size_t namesize = tox_friend_get_name_size(tox, friendnumber, nullptr); - if (namesize == SIZE_MAX) - { - qWarning() << "getFriendUsername: Failed to get name size for friend "< Core::splitMessage(const QString &message, int maxLen) +QList Core::splitMessage(const QString& message, int maxLen) { QList splittedMsgs; QByteArray ba_message(message.toUtf8()); - while (ba_message.size() > maxLen) - { + while (ba_message.size() > maxLen) { int splitPos = ba_message.lastIndexOf(' ', maxLen - 1); - if (splitPos <= 0) - { + if (splitPos <= 0) { splitPos = maxLen; - if (ba_message[splitPos] & 0x80) - { + if (ba_message[splitPos] & 0x80) { do { splitPos--; } while (!(ba_message[splitPos] & 0x40)); @@ -1424,8 +1325,7 @@ QString Core::getPeerName(const ToxPk& id) const { QString name; uint32_t friendId = tox_friend_by_public_key(tox, id.getBytes(), nullptr); - if (friendId == std::numeric_limits::max()) - { + if (friendId == std::numeric_limits::max()) { qWarning() << "getPeerName: No such peer"; return name; } @@ -1434,10 +1334,9 @@ QString Core::getPeerName(const ToxPk& id) const if (nameSize == SIZE_MAX) return name; - uint8_t* cname = new uint8_t[nameSizestop(); toxTimer->stop(); - if (!onlyStop) - { + if (!onlyStop) { delete toxTimer; toxTimer = nullptr; } diff --git a/src/core/core.h b/src/core/core.h index 03671c8e7..5f3574d39 100644 --- a/src/core/core.h +++ b/src/core/core.h @@ -21,19 +21,20 @@ #ifndef CORE_HPP #define CORE_HPP -#include -#include #include +#include +#include #include #include -#include "corestructs.h" #include "coredefines.h" +#include "corestructs.h" #include "toxid.h" class Profile; -template class QList; +template +class QList; class QTimer; class QString; class CString; @@ -54,7 +55,7 @@ public: static const QString TOX_EXT; static const QString CONFIG_FILE_NAME; static QString sanitize(QString name); - static QList splitMessage(const QString &message, int maxLen); + static QList splitMessage(const QString& message, int maxLen); static QByteArray getSaltFromFile(QString filename); @@ -69,8 +70,8 @@ public: QString getFriendUsername(uint32_t friendNumber) const; bool isFriendOnline(uint32_t friendId) const; - bool hasFriendWithPublicKey(const ToxPk &publicKey) const; - uint32_t joinGroupchat(int32_t friendId, uint8_t type, const uint8_t* pubkey,uint16_t length) const; + bool hasFriendWithPublicKey(const ToxPk& publicKey) const; + uint32_t joinGroupchat(int32_t friendId, uint8_t type, const uint8_t* pubkey, uint16_t length) const; void quitGroupChat(int groupId) const; QString getUsername() const; @@ -91,8 +92,8 @@ public slots: QByteArray getToxSaveData(); - void acceptFriendRequest(const ToxPk &friendPk); - void requestFriendship(const ToxId &friendAddress, const QString& message); + void acceptFriendRequest(const ToxPk& friendPk); + void requestFriendship(const ToxId& friendAddress, const QString& message); void groupInviteFriend(uint32_t friendId, int groupId); int createGroup(uint8_t type = TOX_CONFERENCE_TYPE_AV); @@ -186,35 +187,28 @@ signals: void fileSendFailed(uint32_t friendId, const QString& fname); private: - static void onFriendRequest(Tox* tox, const uint8_t* cUserId, - const uint8_t* cMessage, size_t cMessageSize, - void* core); - static void onFriendMessage(Tox* tox, uint32_t friendId, - TOX_MESSAGE_TYPE type, const uint8_t* cMessage, + static void onFriendRequest(Tox* tox, const uint8_t* cUserId, const uint8_t* cMessage, size_t cMessageSize, void* core); - static void onFriendNameChange(Tox* tox, uint32_t friendId, - const uint8_t* cName, size_t cNameSize, - void* core); - static void onFriendTypingChange(Tox* tox, uint32_t friendId, bool isTyping, - void* core); - static void onStatusMessageChanged(Tox* tox, uint32_t friendId, - const uint8_t* cMessage, + static void onFriendMessage(Tox* tox, uint32_t friendId, TOX_MESSAGE_TYPE type, + const uint8_t* cMessage, size_t cMessageSize, void* core); + static void onFriendNameChange(Tox* tox, uint32_t friendId, const uint8_t* cName, + size_t cNameSize, void* core); + static void onFriendTypingChange(Tox* tox, uint32_t friendId, bool isTyping, void* core); + static void onStatusMessageChanged(Tox* tox, uint32_t friendId, const uint8_t* cMessage, size_t cMessageSize, void* core); - static void onUserStatusChanged(Tox* tox, uint32_t friendId, - TOX_USER_STATUS userstatus, void* core); - static void onConnectionStatusChanged(Tox* tox, uint32_t friendId, - TOX_CONNECTION status, void* core); + static void onUserStatusChanged(Tox* tox, uint32_t friendId, TOX_USER_STATUS userstatus, + void* core); + static void onConnectionStatusChanged(Tox* tox, uint32_t friendId, TOX_CONNECTION status, + void* core); static void onGroupInvite(Tox* tox, uint32_t friendId, TOX_CONFERENCE_TYPE type, const uint8_t* data, size_t length, void* vCore); - static void onGroupMessage(Tox* tox, uint32_t groupId, uint32_t peerId, - TOX_MESSAGE_TYPE type, const uint8_t* cMessage, - size_t length, void* vCore); + static void onGroupMessage(Tox* tox, uint32_t groupId, uint32_t peerId, TOX_MESSAGE_TYPE type, + const uint8_t* cMessage, size_t length, void* vCore); static void onGroupNamelistChange(Tox* tox, uint32_t groupId, uint32_t peerId, TOX_CONFERENCE_STATE_CHANGE change, void* core); static void onGroupTitleChange(Tox* tox, uint32_t groupId, uint32_t peerId, const uint8_t* cTitle, size_t length, void* vCore); - static void onReadReceiptCallback(Tox* tox, uint32_t friendId, - uint32_t receipt, void* core); + static void onReadReceiptCallback(Tox* tox, uint32_t friendId, uint32_t receipt, void* core); void sendGroupMessageWithType(int groupId, const QString& message, TOX_MESSAGE_TYPE type); bool parsePeerQueryError(TOX_ERR_CONFERENCE_PEER_QUERY error) const; @@ -235,17 +229,16 @@ private slots: private: Tox* tox; CoreAV* av; - QTimer *toxTimer; + QTimer* toxTimer; Profile& profile; QMutex messageSendMutex; bool ready; - static QThread *coreThread; + static QThread* coreThread; - friend class Audio; ///< Audio can access our calls directly to reduce latency + friend class Audio; ///< Audio can access our calls directly to reduce latency friend class CoreFile; ///< CoreFile can access tox* and emit our signals - friend class CoreAV; ///< CoreAV accesses our toxav* for now + friend class CoreAV; ///< CoreAV accesses our toxav* for now }; #endif // CORE_HPP - diff --git a/src/core/coreav.cpp b/src/core/coreav.cpp index 4cc1d6f4a..ed814f3b9 100644 --- a/src/core/coreav.cpp +++ b/src/core/coreav.cpp @@ -24,14 +24,14 @@ #include "src/friend.h" #include "src/group.h" #include "src/persistence/settings.h" -#include "src/video/videoframe.h" #include "src/video/corevideosource.h" -#include +#include "src/video/videoframe.h" +#include +#include #include #include -#include -#include #include +#include /** * @fn void CoreAV::avInvite(uint32_t friendId, bool video) @@ -57,16 +57,19 @@ /** * @var std::atomic_flag CoreAV::threadSwitchLock - * @brief This flag is to be acquired before switching in a blocking way between the UI and CoreAV thread. + * @brief This flag is to be acquired before switching in a blocking way between the UI and CoreAV + * thread. * - * The CoreAV thread must have priority for the flag, other threads should back off or release it quickly. + * The CoreAV thread must have priority for the flag, other threads should back off or release it + * quickly. * CoreAV needs to interface with three threads, the toxcore/Core thread that fires non-payload * toxav callbacks, the toxav/CoreAV thread that fires AV payload callbacks and manages * most of CoreAV's members, and the UI thread, which calls our [start/answer/cancel]Call functions * and which we call via signals. * When the UI calls us, we switch from the UI thread to the CoreAV thread to do the processing, * when toxcore fires a non-payload av callback, we do the processing in the CoreAV thread and then - * switch to the UI thread to send it a signal. Both switches block both threads, so this would deadlock. + * switch to the UI thread to send it a signal. Both switches block both threads, so this would + * deadlock. */ /** @@ -79,9 +82,10 @@ IndexedList CoreAV::calls; */ IndexedList CoreAV::groupCalls; -CoreAV::CoreAV(Tox *tox) - : coreavThread{new QThread}, iterateTimer{new QTimer{this}}, - threadSwitchLock{false} +CoreAV::CoreAV(Tox* tox) + : coreavThread{new QThread} + , iterateTimer{new QTimer{this}} + , threadSwitchLock{false} { coreavThread->setObjectName("qTox CoreAV"); moveToThread(coreavThread.get()); @@ -107,14 +111,13 @@ CoreAV::~CoreAV() killTimerFromThread(); toxav_kill(toxav); coreavThread->exit(0); - while (coreavThread->isRunning()) - { + while (coreavThread->isRunning()) { qApp->processEvents(); coreavThread->wait(100); } } -const ToxAV *CoreAV::getToxAv() const +const ToxAV* CoreAV::getToxAv() const { return toxav; } @@ -148,7 +151,8 @@ void CoreAV::killTimerFromThread() { // Timers can only be touched from their own thread if (QThread::currentThread() != coreavThread.get()) - return (void)QMetaObject::invokeMethod(this, "killTimerFromThread", Qt::BlockingQueuedConnection); + return (void)QMetaObject::invokeMethod(this, "killTimerFromThread", + Qt::BlockingQueuedConnection); iterateTimer.release(); } @@ -195,9 +199,7 @@ bool CoreAV::isCallStarted(const Group* g) const */ bool CoreAV::isCallActive(const Friend* f) const { - return isCallStarted(f) - ? !(calls[f->getFriendId()].inactive) - : false; + return isCallStarted(f) ? !(calls[f->getFriendId()].inactive) : false; } /** @@ -207,24 +209,18 @@ bool CoreAV::isCallActive(const Friend* f) const */ bool CoreAV::isCallActive(const Group* g) const { - return isCallStarted(g) - ? !(groupCalls[g->getGroupId()].inactive) - : false; + return isCallStarted(g) ? !(groupCalls[g->getGroupId()].inactive) : false; } bool CoreAV::isCallVideoEnabled(const Friend* f) const { - return isCallStarted(f) - ? calls[f->getFriendId()].videoEnabled - : false; + return isCallStarted(f) ? calls[f->getFriendId()].videoEnabled : false; } bool CoreAV::answerCall(uint32_t friendNum) { - if (QThread::currentThread() != coreavThread.get()) - { - if (threadSwitchLock.test_and_set(std::memory_order_acquire)) - { + if (QThread::currentThread() != coreavThread.get()) { + if (threadSwitchLock.test_and_set(std::memory_order_acquire)) { qDebug() << "CoreAV::answerCall: Backed off of thread-switch lock"; return false; } @@ -240,14 +236,11 @@ bool CoreAV::answerCall(uint32_t friendNum) qDebug() << QString("answering call %1").arg(friendNum); assert(calls.contains(friendNum)); TOXAV_ERR_ANSWER err; - if (toxav_answer(toxav, friendNum, AUDIO_DEFAULT_BITRATE, VIDEO_DEFAULT_BITRATE, &err)) - { + if (toxav_answer(toxav, friendNum, AUDIO_DEFAULT_BITRATE, VIDEO_DEFAULT_BITRATE, &err)) { calls[friendNum].inactive = false; return true; - } - else - { - qWarning() << "Failed to answer call with error"< vframe) ToxFriendCall& call = calls[callId]; - if (!call.videoEnabled || call.inactive - || !(call.state & TOXAV_FRIEND_CALL_STATE_ACCEPTING_V)) + if (!call.videoEnabled || call.inactive || !(call.state & TOXAV_FRIEND_CALL_STATE_ACCEPTING_V)) return; - if (call.nullVideoBitrate) - { - qDebug() << "Restarting video stream to friend"<toToxYUVFrame(); - if(!frame) - { + if (!frame) { return; } @@ -418,17 +392,13 @@ void CoreAV::sendCallVideo(uint32_t callId, std::shared_ptr vframe) TOXAV_ERR_SEND_FRAME err; int retries = 0; do { - if (!toxav_video_send_frame(toxav, callId, frame.width, frame.height, - frame.y, frame.u, frame.v, &err)) - { - if (err == TOXAV_ERR_SEND_FRAME_SYNC) - { + if (!toxav_video_send_frame(toxav, callId, frame.width, frame.height, frame.y, frame.u, + frame.v, &err)) { + if (err == TOXAV_ERR_SEND_FRAME_SYNC) { ++retries; QThread::usleep(500); - } - else - { - qDebug() << "toxav_video_send_frame error: "< vframe) */ void CoreAV::toggleMuteCallInput(const Friend* f) { - if (f && calls.contains(f->getFriendId())) - { + if (f && calls.contains(f->getFriendId())) { ToxCall& call = calls[f->getFriendId()]; call.muteMic = !call.muteMic; } @@ -455,8 +424,7 @@ void CoreAV::toggleMuteCallInput(const Friend* f) */ void CoreAV::toggleMuteCallOutput(const Friend* f) { - if (f && calls.contains(f->getFriendId())) - { + if (f && calls.contains(f->getFriendId())) { ToxCall& call = calls[f->getFriendId()]; call.muteVol = !call.muteVol; } @@ -474,18 +442,15 @@ void CoreAV::toggleMuteCallOutput(const Friend* f) * @param[in] sample_rate the audio sample rate * @param[in] core the qTox Core class */ -void CoreAV::groupCallCallback(void* tox, int group, int peer, - const int16_t* data, unsigned samples, - uint8_t channels, unsigned sample_rate, - void* core) +void CoreAV::groupCallCallback(void* tox, int group, int peer, const int16_t* data, + unsigned samples, uint8_t channels, unsigned sample_rate, void* core) { Q_UNUSED(tox); Core* c = static_cast(core); CoreAV* cav = c->getAv(); - if (!cav->groupCalls.contains(group)) - { + if (!cav->groupCalls.contains(group)) { return; } @@ -500,8 +465,7 @@ void CoreAV::groupCallCallback(void* tox, int group, int peer, if (!call.peers[peer]) audio.subscribeOutput(call.peers[peer]); - audio.playAudioBuffer(call.peers[peer], data, samples, channels, - sample_rate); + audio.playAudioBuffer(call.peers[peer], data, samples, channels, sample_rate); } /** @@ -509,8 +473,9 @@ void CoreAV::groupCallCallback(void* tox, int group, int peer, * @param group Group Index * @param peer Peer Index */ -void CoreAV::invalidateGroupCallPeerSource(int group, int peer) { - Audio &audio = Audio::getInstance(); +void CoreAV::invalidateGroupCallPeerSource(int group, int peer) +{ + Audio& audio = Audio::getInstance(); audio.unsubscribeOutput(groupCalls[group].peers[peer]); groupCalls[group].peers[peer] = 0; } @@ -520,11 +485,11 @@ void CoreAV::invalidateGroupCallPeerSource(int group, int peer) { * @param friendNum Id of friend in call list. * @return Video surface to show */ -VideoSource *CoreAV::getVideoSourceFromCall(int friendNum) +VideoSource* CoreAV::getVideoSourceFromCall(int friendNum) { - if (!calls.contains(friendNum)) - { - qWarning() << "CoreAV::getVideoSourceFromCall: No such call, did it die before we finished answering?"; + if (!calls.contains(friendNum)) { + qWarning() << "CoreAV::getVideoSourceFromCall: No such call, did it die before we finished " + "answering?"; return nullptr; } @@ -556,7 +521,8 @@ void CoreAV::leaveGroupCall(int groupId) groupCalls.remove(groupId); } -bool CoreAV::sendGroupCallAudio(int groupId, const int16_t *pcm, size_t samples, uint8_t chans, uint32_t rate) +bool CoreAV::sendGroupCallAudio(int groupId, const int16_t* pcm, size_t samples, uint8_t chans, + uint32_t rate) { if (!groupCalls.contains(groupId)) return false; @@ -601,9 +567,7 @@ void CoreAV::muteCallOutput(const Group* g, bool mute) */ bool CoreAV::isGroupCallInputMuted(const Group* g) const { - return g && groupCalls.contains(g->getGroupId()) - ? groupCalls[g->getGroupId()].muteMic - : false; + return g && groupCalls.contains(g->getGroupId()) ? groupCalls[g->getGroupId()].muteMic : false; } /** @@ -613,9 +577,7 @@ bool CoreAV::isGroupCallInputMuted(const Group* g) const */ bool CoreAV::isGroupCallOutputMuted(const Group* g) const { - return g && groupCalls.contains(g->getGroupId()) - ? groupCalls[g->getGroupId()].muteVol - : false; + return g && groupCalls.contains(g->getGroupId()) ? groupCalls[g->getGroupId()].muteVol : false; } /** @@ -628,12 +590,11 @@ bool CoreAV::isGroupAvEnabled(int groupId) const Tox* tox = Core::getInstance()->tox; TOX_ERR_CONFERENCE_GET_TYPE error; TOX_CONFERENCE_TYPE type = tox_conference_get_type(tox, groupId, &error); - switch (error) - { + switch (error) { case TOX_ERR_CONFERENCE_GET_TYPE_OK: break; case TOX_ERR_CONFERENCE_GET_TYPE_CONFERENCE_NOT_FOUND: - qCritical() << "Conference not found"; + qCritical() << "Conference not found"; break; default: break; @@ -649,9 +610,7 @@ bool CoreAV::isGroupAvEnabled(int groupId) const */ bool CoreAV::isCallInputMuted(const Friend* f) const { - return f && calls.contains(f->getFriendId()) - ? calls[f->getFriendId()].muteMic - : false; + return f && calls.contains(f->getFriendId()) ? calls[f->getFriendId()].muteMic : false; } /** @@ -661,9 +620,7 @@ bool CoreAV::isCallInputMuted(const Friend* f) const */ bool CoreAV::isCallOutputMuted(const Friend* f) const { - return f && calls.contains(f->getFriendId()) - ? calls[f->getFriendId()].muteVol - : false; + return f && calls.contains(f->getFriendId()) ? calls[f->getFriendId()].muteVol : false; } /** @@ -671,13 +628,11 @@ bool CoreAV::isCallOutputMuted(const Friend* f) const */ void CoreAV::invalidateCallSources() { - for (ToxGroupCall& call : groupCalls) - { + for (ToxGroupCall& call : groupCalls) { call.peers.clear(); } - for (ToxFriendCall& call : calls) - { + for (ToxFriendCall& call : calls) { call.alSource = 0; } } @@ -690,8 +645,7 @@ void CoreAV::sendNoVideo() { // We don't change the audio bitrate, but we signal that we're not sending video anymore qDebug() << "CoreAV: Signaling end of video sending"; - for (ToxFriendCall& call : calls) - { + for (ToxFriendCall& call : calls) { toxav_bit_rate_set(toxav, call.callId, -1, 0, nullptr); call.nullVideoBitrate = true; } @@ -701,12 +655,12 @@ void CoreAV::callCallback(ToxAV* toxav, uint32_t friendNum, bool audio, bool vid { CoreAV* self = static_cast(vSelf); - // Run this slow callback asynchronously on the AV thread to avoid deadlocks with what our caller (toxcore) holds + // Run this slow callback asynchronously on the AV thread to avoid deadlocks with what our + // caller (toxcore) holds // Also run the code to switch to the CoreAV thread in yet another thread, in case CoreAV // has threadSwitchLock and wants a toxcore lock that our call stack is holding... - if (QThread::currentThread() != self->coreavThread.get()) - { - QtConcurrent::run([=](){ + if (QThread::currentThread() != self->coreavThread.get()) { + QtConcurrent::run([=]() { // We assume the original caller doesn't come from the CoreAV thread here while (self->threadSwitchLock.test_and_set(std::memory_order_acquire)) QThread::yieldCurrentThread(); // Shouldn't spin for long, we have priority @@ -718,11 +672,11 @@ void CoreAV::callCallback(ToxAV* toxav, uint32_t friendNum, bool audio, bool vid return; } - if (self->calls.contains(friendNum)) - { + if (self->calls.contains(friendNum)) { /// Hanging up from a callback is supposed to be UB, /// but since currently the toxav callbacks are fired from the toxcore thread, - /// we'll always reach this point through a non-blocking queud connection, so not in the callback. + /// we'll always reach this point through a non-blocking queud connection, so not in the + /// callback. qWarning() << QString("Rejecting call invite from %1, we're already in that call!").arg(friendNum); toxav_call_control(toxav, friendNum, TOXAV_CALL_CONTROL_CANCEL, nullptr); return; @@ -746,25 +700,24 @@ void CoreAV::stateCallback(ToxAV* toxav, uint32_t friendNum, uint32_t state, voi { CoreAV* self = static_cast(vSelf); - // Run this slow callback asynchronously on the AV thread to avoid deadlocks with what our caller (toxcore) holds + // Run this slow callback asynchronously on the AV thread to avoid deadlocks with what our + // caller (toxcore) holds // Also run the code to switch to the CoreAV thread in yet another thread, in case CoreAV // has threadSwitchLock and wants a toxcore lock that our call stack is holding... - if (QThread::currentThread() != self->coreavThread.get()) - { - QtConcurrent::run([=](){ + if (QThread::currentThread() != self->coreavThread.get()) { + QtConcurrent::run([=]() { // We assume the original caller doesn't come from the CoreAV thread here while (self->threadSwitchLock.test_and_set(std::memory_order_acquire)) QThread::yieldCurrentThread(); // Shouldn't spin for long, we have priority QMetaObject::invokeMethod(self, "stateCallback", Qt::QueuedConnection, - Q_ARG(ToxAV*, toxav), Q_ARG(uint32_t, friendNum), - Q_ARG(uint32_t, state), Q_ARG(void*, vSelf)); + Q_ARG(ToxAV*, toxav), Q_ARG(uint32_t, friendNum), + Q_ARG(uint32_t, state), Q_ARG(void*, vSelf)); }); return; } - if (!self->calls.contains(friendNum)) - { + if (!self->calls.contains(friendNum)) { qWarning() << QString("stateCallback called, but call %1 is already dead").arg(friendNum); self->threadSwitchLock.clear(std::memory_order_release); return; @@ -772,40 +725,32 @@ void CoreAV::stateCallback(ToxAV* toxav, uint32_t friendNum, uint32_t state, voi ToxFriendCall& call = self->calls[friendNum]; - if (state & TOXAV_FRIEND_CALL_STATE_ERROR) - { - qWarning() << "Call with friend"<avEnd(friendNum); - } - else if (state & TOXAV_FRIEND_CALL_STATE_FINISHED) - { - qDebug() << "Call with friend"<avEnd(friendNum); - } - else - { + } else { // If our state was null, we started the call and were still ringing - if (!call.state && state) - { + if (!call.state && state) { call.stopTimeout(); call.inactive = false; emit self->avStart(friendNum, call.videoEnabled); - } - else if ((call.state & TOXAV_FRIEND_CALL_STATE_SENDING_V) - && !(state & TOXAV_FRIEND_CALL_STATE_SENDING_V)) - { - qDebug() << "Friend"<stopSource(); - } - else if (!(call.state & TOXAV_FRIEND_CALL_STATE_SENDING_V) - && (state & TOXAV_FRIEND_CALL_STATE_SENDING_V)) - { - // Workaround toxav sometimes firing callbacks for "send last frame" -> "stop sending video" + } else if (!(call.state & TOXAV_FRIEND_CALL_STATE_SENDING_V) + && (state & TOXAV_FRIEND_CALL_STATE_SENDING_V)) { + // Workaround toxav sometimes firing callbacks for "send last frame" -> "stop sending + // video" // out of orders (even though they were sent in order by the other end). - // We simply stop the videoSource from emitting anything while the other end says it's not sending + // We simply stop the videoSource from emitting anything while the other end says it's + // not sending if (call.videoSource) call.videoSource->restartSource(); } @@ -815,23 +760,25 @@ void CoreAV::stateCallback(ToxAV* toxav, uint32_t friendNum, uint32_t state, voi self->threadSwitchLock.clear(std::memory_order_release); } -void CoreAV::bitrateCallback(ToxAV* toxav, uint32_t friendNum, uint32_t arate, uint32_t vrate, void* vSelf) +void CoreAV::bitrateCallback(ToxAV* toxav, uint32_t friendNum, uint32_t arate, uint32_t vrate, + void* vSelf) { CoreAV* self = static_cast(vSelf); // Run this slow path callback asynchronously on the AV thread to avoid deadlocks - if (QThread::currentThread() != self->coreavThread.get()) - { + if (QThread::currentThread() != self->coreavThread.get()) { return (void)QMetaObject::invokeMethod(self, "bitrateCallback", Qt::QueuedConnection, - Q_ARG(ToxAV*, toxav), Q_ARG(uint32_t, friendNum), - Q_ARG(uint32_t, arate), Q_ARG(uint32_t, vrate), Q_ARG(void*, vSelf)); + Q_ARG(ToxAV*, toxav), Q_ARG(uint32_t, friendNum), + Q_ARG(uint32_t, arate), Q_ARG(uint32_t, vrate), + Q_ARG(void*, vSelf)); } - qDebug() << "Recommended bitrate with"<(vSelf); if (!self->calls.contains(friendNum)) @@ -849,9 +796,9 @@ void CoreAV::audioFrameCallback(ToxAV *, uint32_t friendNum, const int16_t *pcm, audio.playAudioBuffer(call.alSource, pcm, sampleCount, channels, samplingRate); } -void CoreAV::videoFrameCallback(ToxAV *, uint32_t friendNum, uint16_t w, uint16_t h, - const uint8_t *y, const uint8_t *u, const uint8_t *v, - int32_t ystride, int32_t ustride, int32_t vstride, void *) +void CoreAV::videoFrameCallback(ToxAV*, uint32_t friendNum, uint16_t w, uint16_t h, + const uint8_t* y, const uint8_t* u, const uint8_t* v, + int32_t ystride, int32_t ustride, int32_t vstride, void*) { if (!calls.contains(friendNum)) return; diff --git a/src/core/coreav.h b/src/core/coreav.h index f323633ea..b714a251c 100644 --- a/src/core/coreav.h +++ b/src/core/coreav.h @@ -21,10 +21,10 @@ #ifndef COREAV_H #define COREAV_H -#include -#include -#include #include "src/core/toxcall.h" +#include +#include +#include #include class Friend; @@ -54,9 +54,11 @@ public: bool isCallActive(const Friend* f) const; bool isCallActive(const Group* g) const; bool isCallVideoEnabled(const Friend* f) const; - bool sendCallAudio(uint32_t friendNum, const int16_t *pcm, size_t samples, uint8_t chans, uint32_t rate); + bool sendCallAudio(uint32_t friendNum, const int16_t* pcm, size_t samples, uint8_t chans, + uint32_t rate); void sendCallVideo(uint32_t friendNum, std::shared_ptr frame); - bool sendGroupCallAudio(int groupNum, const int16_t *pcm, size_t samples, uint8_t chans, uint32_t rate); + bool sendGroupCallAudio(int groupNum, const int16_t* pcm, size_t samples, uint8_t chans, + uint32_t rate); VideoSource* getVideoSourceFromCall(int callNumber); void invalidateCallSources(); @@ -75,14 +77,12 @@ public: void toggleMuteCallInput(const Friend* f); void toggleMuteCallOutput(const Friend* f); - static void groupCallCallback(void* tox, int group, int peer, - const int16_t* data, unsigned samples, - uint8_t channels, unsigned sample_rate, - void* core); + static void groupCallCallback(void* tox, int group, int peer, const int16_t* data, unsigned samples, + uint8_t channels, unsigned sample_rate, void* core); static void invalidateGroupCallPeerSource(int group, int peer); public slots: - bool startCall(uint32_t friendNum, bool video=false); + bool startCall(uint32_t friendNum, bool video = false); bool answerCall(uint32_t friendNum); bool cancelCall(uint32_t friendNum); void timeoutCall(uint32_t friendNum); @@ -95,17 +95,19 @@ signals: void avEnd(uint32_t friendId); private slots: - static void callCallback(ToxAV *toxAV, uint32_t friendNum, bool audio, bool video, void* self); - static void stateCallback(ToxAV *, uint32_t friendNum, uint32_t state, void* self); - static void bitrateCallback(ToxAV *toxAV, uint32_t friendNum, uint32_t arate, uint32_t vrate, void* self); + static void callCallback(ToxAV* toxAV, uint32_t friendNum, bool audio, bool video, void* self); + static void stateCallback(ToxAV*, uint32_t friendNum, uint32_t state, void* self); + static void bitrateCallback(ToxAV* toxAV, uint32_t friendNum, uint32_t arate, uint32_t vrate, + void* self); void killTimerFromThread(); private: void process(); - static void audioFrameCallback(ToxAV *toxAV, uint32_t friendNum, const int16_t *pcm, size_t sampleCount, - uint8_t channels, uint32_t samplingRate, void* self); - static void videoFrameCallback(ToxAV *toxAV, uint32_t friendNum, uint16_t w, uint16_t h, - const uint8_t *y, const uint8_t *u, const uint8_t *v, + static void audioFrameCallback(ToxAV* toxAV, uint32_t friendNum, const int16_t* pcm, + size_t sampleCount, uint8_t channels, uint32_t samplingRate, + void* self); + static void videoFrameCallback(ToxAV* toxAV, uint32_t friendNum, uint16_t w, uint16_t h, + const uint8_t* y, const uint8_t* u, const uint8_t* v, int32_t ystride, int32_t ustride, int32_t vstride, void* self); private: diff --git a/src/core/corefile.cpp b/src/core/corefile.cpp index 55be397aa..3ee925baa 100644 --- a/src/core/corefile.cpp +++ b/src/core/corefile.cpp @@ -22,12 +22,12 @@ #include "corefile.h" #include "corestructs.h" #include "src/core/cstring.h" -#include "src/persistence/settings.h" #include "src/persistence/profile.h" +#include "src/persistence/settings.h" #include +#include #include #include -#include #include /** @@ -55,13 +55,10 @@ unsigned CoreFile::corefileIterationInterval() comes to CPU usage – just keep the CPU usage low when there are no file transfers, and speed things up when there is an ongoing file transfer. */ - constexpr unsigned fileInterval = 10, - idleInterval = 1000; + constexpr unsigned fileInterval = 10, idleInterval = 1000; - for (ToxFile& file : fileMap) - { - if (file.status == ToxFile::TRANSMITTING) - { + for (ToxFile& file : fileMap) { + if (file.status == ToxFile::TRANSMITTING) { return fileInterval; } } @@ -72,10 +69,8 @@ void CoreFile::sendAvatarFile(Core* core, uint32_t friendId, const QByteArray& d { QMutexLocker mlocker(&fileSendMutex); - if (data.isEmpty()) - { - tox_file_send(core->tox, friendId, TOX_FILE_KIND_AVATAR, 0, - nullptr, nullptr, 0, nullptr); + if (data.isEmpty()) { + tox_file_send(core->tox, friendId, TOX_FILE_KIND_AVATAR, 0, nullptr, nullptr, 0, nullptr); return; } @@ -86,10 +81,9 @@ void CoreFile::sendAvatarFile(Core* core, uint32_t friendId, const QByteArray& d TOX_ERR_FILE_SEND error; uint32_t fileNum = tox_file_send(core->tox, friendId, TOX_FILE_KIND_AVATAR, filesize, - avatarHash, avatarHash, TOX_HASH_LENGTH, &error); + avatarHash, avatarHash, TOX_HASH_LENGTH, &error); - switch (error) - { + switch (error) { case TOX_ERR_FILE_SEND_OK: break; case TOX_ERR_FILE_SEND_FRIEND_NOT_CONNECTED: @@ -121,15 +115,15 @@ void CoreFile::sendAvatarFile(Core* core, uint32_t friendId, const QByteArray& d addFile(friendId, fileNum, file); } -void CoreFile::sendFile(Core* core, uint32_t friendId, QString filename, QString filePath, long long filesize) +void CoreFile::sendFile(Core* core, uint32_t friendId, QString filename, QString filePath, + long long filesize) { QMutexLocker mlocker(&fileSendMutex); QByteArray fileName = filename.toUtf8(); uint32_t fileNum = tox_file_send(core->tox, friendId, TOX_FILE_KIND_DATA, filesize, nullptr, - (uint8_t*)fileName.data(), fileName.size(), nullptr); - if (fileNum == std::numeric_limits::max()) - { + (uint8_t*)fileName.data(), fileName.size(), nullptr); + if (fileNum == std::numeric_limits::max()) { qWarning() << "sendFile: Can't create the Tox file sender"; emit core->fileSendFailed(friendId, filename); return; @@ -140,8 +134,7 @@ void CoreFile::sendFile(Core* core, uint32_t friendId, QString filename, QString file.filesize = filesize; file.resumeFileId.resize(TOX_FILE_ID_LENGTH); tox_file_get_file_id(core->tox, friendId, fileNum, (uint8_t*)file.resumeFileId.data(), nullptr); - if (!file.open(false)) - { + if (!file.open(false)) { qWarning() << QString("sendFile: Can't open file, error: %1").arg(file.file->errorString()); } @@ -153,25 +146,19 @@ void CoreFile::sendFile(Core* core, uint32_t friendId, QString filename, QString void CoreFile::pauseResumeFileSend(Core* core, uint32_t friendId, uint32_t fileId) { ToxFile* file = findFile(friendId, fileId); - if (!file) - { + if (!file) { qWarning("pauseResumeFileSend: No such file in queue"); return; } - if (file->status == ToxFile::TRANSMITTING) - { + if (file->status == ToxFile::TRANSMITTING) { file->status = ToxFile::PAUSED; emit core->fileTransferPaused(*file); tox_file_control(core->tox, file->friendId, file->fileNum, TOX_FILE_CONTROL_PAUSE, nullptr); - } - else if (file->status == ToxFile::PAUSED) - { + } else if (file->status == ToxFile::PAUSED) { file->status = ToxFile::TRANSMITTING; emit core->fileTransferAccepted(*file); tox_file_control(core->tox, file->friendId, file->fileNum, TOX_FILE_CONTROL_RESUME, nullptr); - } - else - { + } else { qWarning() << "pauseResumeFileSend: File is stopped"; } } @@ -179,25 +166,19 @@ void CoreFile::pauseResumeFileSend(Core* core, uint32_t friendId, uint32_t fileI void CoreFile::pauseResumeFileRecv(Core* core, uint32_t friendId, uint32_t fileId) { ToxFile* file = findFile(friendId, fileId); - if (!file) - { + if (!file) { qWarning("cancelFileRecv: No such file in queue"); return; } - if (file->status == ToxFile::TRANSMITTING) - { + if (file->status == ToxFile::TRANSMITTING) { file->status = ToxFile::PAUSED; emit core->fileTransferPaused(*file); tox_file_control(core->tox, file->friendId, file->fileNum, TOX_FILE_CONTROL_PAUSE, nullptr); - } - else if (file->status == ToxFile::PAUSED) - { + } else if (file->status == ToxFile::PAUSED) { file->status = ToxFile::TRANSMITTING; emit core->fileTransferAccepted(*file); tox_file_control(core->tox, file->friendId, file->fileNum, TOX_FILE_CONTROL_RESUME, nullptr); - } - else - { + } else { qWarning() << "pauseResumeFileRecv: File is stopped or broken"; } } @@ -205,8 +186,7 @@ void CoreFile::pauseResumeFileRecv(Core* core, uint32_t friendId, uint32_t fileI void CoreFile::cancelFileSend(Core* core, uint32_t friendId, uint32_t fileId) { ToxFile* file = findFile(friendId, fileId); - if (!file) - { + if (!file) { qWarning("cancelFileSend: No such file in queue"); return; } @@ -220,8 +200,7 @@ void CoreFile::cancelFileSend(Core* core, uint32_t friendId, uint32_t fileId) void CoreFile::cancelFileRecv(Core* core, uint32_t friendId, uint32_t fileId) { ToxFile* file = findFile(friendId, fileId); - if (!file) - { + if (!file) { qWarning("cancelFileRecv: No such file in queue"); return; } @@ -234,8 +213,7 @@ void CoreFile::cancelFileRecv(Core* core, uint32_t friendId, uint32_t fileId) void CoreFile::rejectFileRecvRequest(Core* core, uint32_t friendId, uint32_t fileId) { ToxFile* file = findFile(friendId, fileId); - if (!file) - { + if (!file) { qWarning("rejectFileRecvRequest: No such file in queue"); return; } @@ -248,14 +226,12 @@ void CoreFile::rejectFileRecvRequest(Core* core, uint32_t friendId, uint32_t fil void CoreFile::acceptFileRecvRequest(Core* core, uint32_t friendId, uint32_t fileId, QString path) { ToxFile* file = findFile(friendId, fileId); - if (!file) - { + if (!file) { qWarning("acceptFileRecvRequest: No such file in queue"); return; } file->setFilePath(path); - if (!file->open(true)) - { + if (!file->open(true)) { qWarning() << "acceptFileRecvRequest: Unable to open file"; return; } @@ -267,13 +243,11 @@ void CoreFile::acceptFileRecvRequest(Core* core, uint32_t friendId, uint32_t fil ToxFile* CoreFile::findFile(uint32_t friendId, uint32_t fileId) { uint64_t key = getFriendKey(friendId, fileId); - if (fileMap.contains(key)) - { + if (fileMap.contains(key)) { return &fileMap[key]; } - qWarning() << "findFile: File transfer with ID" << friendId << ':' - << fileId << "doesn't exist"; + qWarning() << "findFile: File transfer with ID" << friendId << ':' << fileId << "doesn't exist"; return nullptr; } @@ -281,10 +255,9 @@ void CoreFile::addFile(uint32_t friendId, uint32_t fileId, const ToxFile& file) { uint64_t key = getFriendKey(friendId, fileId); - if (fileMap.contains(key)) - { - qWarning() << "addFile: Overwriting existing file transfer with same ID" - << friendId << ':' << fileId; + if (fileMap.contains(key)) { + qWarning() << "addFile: Overwriting existing file transfer with same ID" << friendId << ':' + << fileId; } fileMap.insert(key, file); @@ -293,8 +266,7 @@ void CoreFile::addFile(uint32_t friendId, uint32_t fileId, const ToxFile& file) void CoreFile::removeFile(uint32_t friendId, uint32_t fileId) { uint64_t key = getFriendKey(friendId, fileId); - if (!fileMap.contains(key)) - { + if (!fileMap.contains(key)) { qWarning() << "removeFile: No such file in queue"; return; } @@ -302,52 +274,49 @@ void CoreFile::removeFile(uint32_t friendId, uint32_t fileId) fileMap.remove(key); } -void CoreFile::onFileReceiveCallback(Tox*, uint32_t friendId, uint32_t fileId, - uint32_t kind, uint64_t filesize, - const uint8_t* fname, size_t fnameLen, +void CoreFile::onFileReceiveCallback(Tox*, uint32_t friendId, uint32_t fileId, uint32_t kind, + uint64_t filesize, const uint8_t* fname, size_t fnameLen, void* vCore) { Core* core = static_cast(vCore); - if (kind == TOX_FILE_KIND_AVATAR) - { + if (kind == TOX_FILE_KIND_AVATAR) { // TODO: port this to ToxPk QString friendAddr = core->getFriendPublicKey(friendId).toString(); - if (!filesize) - { + if (!filesize) { qDebug() << QString("Received empty avatar request %1:%2").arg(friendId).arg(fileId); // Avatars of size 0 means explicitely no avatar emit core->friendAvatarRemoved(friendId); core->profile.removeAvatar(friendAddr); return; - } - else - { - static_assert(TOX_HASH_LENGTH <= TOX_FILE_ID_LENGTH, "TOX_HASH_LENGTH > TOX_FILE_ID_LENGTH!"); + } else { + static_assert(TOX_HASH_LENGTH <= TOX_FILE_ID_LENGTH, + "TOX_HASH_LENGTH > TOX_FILE_ID_LENGTH!"); uint8_t avatarHash[TOX_FILE_ID_LENGTH]; tox_file_get_file_id(core->tox, friendId, fileId, avatarHash, nullptr); - if (core->profile.getAvatarHash(friendAddr) == QByteArray((char*)avatarHash, TOX_HASH_LENGTH)) - { + if (core->profile.getAvatarHash(friendAddr) + == QByteArray((char*)avatarHash, TOX_HASH_LENGTH)) { // If it's an avatar but we already have it cached, cancel - qDebug() << QString("Received avatar request %1:%2, reject, since we have it in cache.").arg(friendId).arg(fileId); + qDebug() << QString( + "Received avatar request %1:%2, reject, since we have it in cache.") + .arg(friendId) + .arg(fileId); tox_file_control(core->tox, friendId, fileId, TOX_FILE_CONTROL_CANCEL, nullptr); return; - } - else - { + } else { // It's an avatar and we don't have it, autoaccept the transfer - qDebug() << QString("Received avatar request %1:%2, accept, since we don't have it in cache.").arg(friendId).arg(fileId); + qDebug() << QString("Received avatar request %1:%2, accept, since we don't have it " + "in cache.") + .arg(friendId) + .arg(fileId); tox_file_control(core->tox, friendId, fileId, TOX_FILE_CONTROL_RESUME, nullptr); } } - } - else - { - qDebug() << QString("Received file request %1:%2 kind %3") - .arg(friendId).arg(fileId).arg(kind); + } else { + qDebug() << QString("Received file request %1:%2 kind %3").arg(friendId).arg(fileId).arg(kind); } - ToxFile file{fileId, friendId, QByteArray((char*)fname,fnameLen), "", ToxFile::RECEIVING}; + ToxFile file{fileId, friendId, QByteArray((char*)fname, fnameLen), "", ToxFile::RECEIVING}; file.filesize = filesize; file.fileKind = kind; file.resumeFileId.resize(TOX_FILE_ID_LENGTH); @@ -357,59 +326,48 @@ void CoreFile::onFileReceiveCallback(Tox*, uint32_t friendId, uint32_t fileId, emit core->fileReceiveRequested(file); } void CoreFile::onFileControlCallback(Tox*, uint32_t friendId, uint32_t fileId, - TOX_FILE_CONTROL control, void *core) + TOX_FILE_CONTROL control, void* core) { ToxFile* file = findFile(friendId, fileId); - if (!file) - { + if (!file) { qWarning("onFileControlCallback: No such file in queue"); return; } - if (control == TOX_FILE_CONTROL_CANCEL) - { + if (control == TOX_FILE_CONTROL_CANCEL) { if (file->fileKind != TOX_FILE_KIND_AVATAR) - qDebug() << "File tranfer"<(core)->fileTransferCancelled(*file); removeFile(friendId, fileId); - } - else if (control == TOX_FILE_CONTROL_PAUSE) - { - qDebug() << "onFileControlCallback: Received pause for file "<status = ToxFile::PAUSED; emit static_cast(core)->fileTransferRemotePausedUnpaused(*file, true); - } - else if (control == TOX_FILE_CONTROL_RESUME) - { + } else if (control == TOX_FILE_CONTROL_RESUME) { if (file->direction == ToxFile::SENDING && file->fileKind == TOX_FILE_KIND_AVATAR) - qDebug() << "Avatar transfer"<status = ToxFile::TRANSMITTING; emit static_cast(core)->fileTransferRemotePausedUnpaused(*file, false); - } - else - { - qWarning() << "Unhandled file control "<fileKind != TOX_FILE_KIND_AVATAR) - { + if (!length) { + if (file->fileKind != TOX_FILE_KIND_AVATAR) { emit static_cast(core)->fileTransferFinished(*file); emit static_cast(core)->fileUploadFinished(file->filePath); } @@ -420,18 +378,14 @@ void CoreFile::onFileDataCallback(Tox *tox, uint32_t friendId, uint32_t fileId, unique_ptr data(new uint8_t[length]); int64_t nread; - if (file->fileKind == TOX_FILE_KIND_AVATAR) - { + if (file->fileKind == TOX_FILE_KIND_AVATAR) { QByteArray chunk = file->avatarData.mid(pos, length); nread = chunk.size(); memcpy(data.get(), chunk.data(), nread); - } - else - { + } else { file->file->seek(pos); nread = file->file->read((char*)data.get(), length); - if (nread <= 0) - { + if (nread <= 0) { qWarning("onFileDataCallback: Failed to read from file"); emit static_cast(core)->fileTransferCancelled(*file); tox_file_send_chunk(tox, friendId, fileId, pos, nullptr, 0, nullptr); @@ -441,8 +395,7 @@ void CoreFile::onFileDataCallback(Tox *tox, uint32_t friendId, uint32_t fileId, file->bytesSent += length; } - if (!tox_file_send_chunk(tox, friendId, fileId, pos, data.get(), nread, nullptr)) - { + if (!tox_file_send_chunk(tox, friendId, fileId, pos, data.get(), nread, nullptr)) { qWarning("onFileDataCallback: Failed to send data chunk"); return; } @@ -450,22 +403,18 @@ void CoreFile::onFileDataCallback(Tox *tox, uint32_t friendId, uint32_t fileId, emit static_cast(core)->fileTransferInfo(*file); } -void CoreFile::onFileRecvChunkCallback(Tox *tox, uint32_t friendId, - uint32_t fileId, uint64_t position, - const uint8_t* data, size_t length, - void* vCore) +void CoreFile::onFileRecvChunkCallback(Tox* tox, uint32_t friendId, uint32_t fileId, uint64_t position, + const uint8_t* data, size_t length, void* vCore) { Core* core = static_cast(vCore); ToxFile* file = findFile(friendId, fileId); - if (!file) - { + if (!file) { qWarning("onFileRecvChunkCallback: No such file in queue"); tox_file_control(tox, friendId, fileId, TOX_FILE_CONTROL_CANCEL, nullptr); return; } - if (file->bytesSent != position) - { + if (file->bytesSent != position) { qWarning("onFileRecvChunkCallback: Received a chunk out-of-order, aborting transfer"); if (file->fileKind != TOX_FILE_KIND_AVATAR) emit core->fileTransferCancelled(*file); @@ -474,21 +423,17 @@ void CoreFile::onFileRecvChunkCallback(Tox *tox, uint32_t friendId, return; } - if (!length) - { - if (file->fileKind == TOX_FILE_KIND_AVATAR) - { + if (!length) { + if (file->fileKind == TOX_FILE_KIND_AVATAR) { QPixmap pic; pic.loadFromData(file->avatarData); - if (!pic.isNull()) - { - qDebug() << "Got"<avatarData.size()<<"bytes of avatar data from" <profile.saveAvatar(file->avatarData, core->getFriendPublicKey(friendId).toString()); + if (!pic.isNull()) { + qDebug() << "Got" << file->avatarData.size() << "bytes of avatar data from" << friendId; + core->profile.saveAvatar(file->avatarData, + core->getFriendPublicKey(friendId).toString()); emit core->friendAvatarChanged(friendId, pic); } - } - else - { + } else { emit core->fileTransferFinished(*file); emit core->fileDownloadFinished(file->filePath); } @@ -499,7 +444,7 @@ void CoreFile::onFileRecvChunkCallback(Tox *tox, uint32_t friendId, if (file->fileKind == TOX_FILE_KIND_AVATAR) file->avatarData.append((char*)data, length); else - file->file->write((char*)data,length); + file->file->write((char*)data, length); file->bytesSent += length; if (file->fileKind != TOX_FILE_KIND_AVATAR) @@ -513,11 +458,11 @@ void CoreFile::onConnectionStatusChanged(Core* core, uint32_t friendId, bool onl // - Start a new file transfer with the same 32byte file ID with toxcore // - Seek to the correct position again // - Update the fileNum in our ToxFile - // - Update the users of our signals to check the 32byte tox file ID, not the uint32_t file_num (fileId) + // - Update the users of our signals to check the 32byte tox file ID, not the uint32_t file_num + // (fileId) ToxFile::FileStatus status = online ? ToxFile::TRANSMITTING : ToxFile::BROKEN; - for (uint64_t key : fileMap.keys()) - { - if (key>>32 != friendId) + for (uint64_t key : fileMap.keys()) { + if (key >> 32 != friendId) continue; fileMap[key].status = status; emit core->fileTransferBrokenUnbroken(fileMap[key], !online); diff --git a/src/core/corefile.h b/src/core/corefile.h index c96f4416c..074bac57e 100644 --- a/src/core/corefile.h +++ b/src/core/corefile.h @@ -21,16 +21,16 @@ #ifndef COREFILE_H #define COREFILE_H -#include #include +#include #include #include #include "corestructs.h" -#include -#include #include +#include +#include struct Tox; class Core; @@ -40,38 +40,20 @@ class CoreFile friend class Core; private: - CoreFile()=delete; + CoreFile() = delete; // Internal file sending APIs, used by Core. Public API in core.h private: - static void sendFile(Core *core, - uint32_t friendId, - QString filename, - QString filePath, + static void sendFile(Core* core, uint32_t friendId, QString filename, QString filePath, long long filesize); - static void sendAvatarFile(Core* core, - uint32_t friendId, - const QByteArray& data); - static void pauseResumeFileSend(Core* core, - uint32_t friendId, - uint32_t fileId); - static void pauseResumeFileRecv(Core* core, - uint32_t friendId, - uint32_t fileId); - static void cancelFileSend(Core* core, - uint32_t friendId, - uint32_t fileId); - static void cancelFileRecv(Core* core, - uint32_t friendId, - uint32_t fileId); - static void rejectFileRecvRequest(Core* core, - uint32_t friendId, - uint32_t fileId); - static void acceptFileRecvRequest(Core* core, - uint32_t friendId, - uint32_t fileId, - QString path); - static ToxFile *findFile(uint32_t friendId, uint32_t fileId); + static void sendAvatarFile(Core* core, uint32_t friendId, const QByteArray& data); + static void pauseResumeFileSend(Core* core, uint32_t friendId, uint32_t fileId); + static void pauseResumeFileRecv(Core* core, uint32_t friendId, uint32_t fileId); + static void cancelFileSend(Core* core, uint32_t friendId, uint32_t fileId); + static void cancelFileRecv(Core* core, uint32_t friendId, uint32_t fileId); + static void rejectFileRecvRequest(Core* core, uint32_t friendId, uint32_t fileId); + static void acceptFileRecvRequest(Core* core, uint32_t friendId, uint32_t fileId, QString path); + static ToxFile* findFile(uint32_t friendId, uint32_t fileId); static void addFile(uint32_t friendId, uint32_t fileId, const ToxFile& file); static void removeFile(uint32_t friendId, uint32_t fileId); static unsigned corefileIterationInterval(); @@ -81,28 +63,16 @@ private: } private: - static void onFileReceiveCallback(Tox*, - uint32_t friendId, - uint32_t fileId, - uint32_t kind, - uint64_t filesize, - const uint8_t* fname, - size_t fnameLen, - void *vCore); - static void onFileControlCallback(Tox *tox, uint32_t friendId, uint32_t fileId, - TOX_FILE_CONTROL control, void *core); - static void onFileDataCallback(Tox *tox, uint32_t friendId, uint32_t fileId, - uint64_t pos, size_t length, void *core); - static void onFileRecvChunkCallback(Tox *tox, - uint32_t friendId, - uint32_t fileId, - uint64_t position, - const uint8_t* data, - size_t length, - void *vCore); - static void onConnectionStatusChanged(Core* core, - uint32_t friendId, - bool online); + static void onFileReceiveCallback(Tox*, uint32_t friendId, uint32_t fileId, uint32_t kind, + uint64_t filesize, const uint8_t* fname, size_t fnameLen, + void* vCore); + static void onFileControlCallback(Tox* tox, uint32_t friendId, uint32_t fileId, + TOX_FILE_CONTROL control, void* core); + static void onFileDataCallback(Tox* tox, uint32_t friendId, uint32_t fileId, uint64_t pos, + size_t length, void* core); + static void onFileRecvChunkCallback(Tox* tox, uint32_t friendId, uint32_t fileId, uint64_t position, + const uint8_t* data, size_t length, void* vCore); + static void onConnectionStatusChanged(Core* core, uint32_t friendId, bool online); private: static QMutex fileSendMutex; diff --git a/src/core/corestructs.cpp b/src/core/corestructs.cpp index 9277336ec..2351c5e3d 100644 --- a/src/core/corestructs.cpp +++ b/src/core/corestructs.cpp @@ -1,10 +1,10 @@ #include "src/core/corestructs.h" #include "src/core/core.h" -#include #include #include +#include -#define TOX_HEX_ID_LENGTH 2*TOX_ADDRESS_SIZE +#define TOX_HEX_ID_LENGTH 2 * TOX_ADDRESS_SIZE /** * @file corestructs.h @@ -23,9 +23,8 @@ */ bool DhtServer::operator==(const DhtServer& other) const { - return this == &other || - (port == other.port && address == other.address && - userId == other.userId && name == other.name); + return this == &other || (port == other.port && address == other.address + && userId == other.userId && name == other.name); } /** @@ -41,26 +40,35 @@ bool DhtServer::operator!=(const DhtServer& other) const /** * @brief ToxFile constructor */ -ToxFile::ToxFile(uint32_t fileNum, uint32_t friendId, QByteArray filename, QString filePath, FileDirection Direction) - : fileKind{TOX_FILE_KIND_DATA}, fileNum(fileNum), friendId(friendId), fileName{filename}, - filePath{filePath}, file{new QFile(filePath)}, bytesSent{0}, filesize{0}, - status{STOPPED}, direction{Direction} +ToxFile::ToxFile(uint32_t fileNum, uint32_t friendId, QByteArray filename, QString filePath, + FileDirection Direction) + : fileKind{TOX_FILE_KIND_DATA} + , fileNum(fileNum) + , friendId(friendId) + , fileName{filename} + , filePath{filePath} + , file{new QFile(filePath)} + , bytesSent{0} + , filesize{0} + , status{STOPPED} + , direction{Direction} { } -bool ToxFile::operator==(const ToxFile &other) const +bool ToxFile::operator==(const ToxFile& other) const { - return (fileNum == other.fileNum) && (friendId == other.friendId) && (direction == other.direction); + return (fileNum == other.fileNum) && (friendId == other.friendId) + && (direction == other.direction); } -bool ToxFile::operator!=(const ToxFile &other) const +bool ToxFile::operator!=(const ToxFile& other) const { return !(*this == other); } void ToxFile::setFilePath(QString path) { - filePath=path; + filePath = path; file->setFileName(path); } diff --git a/src/core/corestructs.h b/src/core/corestructs.h index de38a8484..93ec81041 100644 --- a/src/core/corestructs.h +++ b/src/core/corestructs.h @@ -7,7 +7,13 @@ class QFile; class QTimer; -enum class Status : int {Online = 0, Away, Busy, Offline}; +enum class Status : int +{ + Online = 0, + Away, + Busy, + Offline +}; struct DhtServer { @@ -37,8 +43,11 @@ struct ToxFile }; ToxFile() = default; - ToxFile(uint32_t FileNum, uint32_t FriendId, QByteArray FileName, QString filePath, FileDirection Direction); - ~ToxFile(){} + ToxFile(uint32_t FileNum, uint32_t FriendId, QByteArray FileName, QString filePath, + FileDirection Direction); + ~ToxFile() + { + } bool operator==(const ToxFile& other) const; bool operator!=(const ToxFile& other) const; diff --git a/src/core/cstring.cpp b/src/core/cstring.cpp index 0c37582fd..b031fe8c8 100644 --- a/src/core/cstring.cpp +++ b/src/core/cstring.cpp @@ -21,8 +21,8 @@ #include "cstring.h" #include -CString::CString(const QString& string) : - CString(string.toUtf8()) +CString::CString(const QString& string) + : CString(string.toUtf8()) { } @@ -33,7 +33,7 @@ CString::CString(const QByteArray& ba_string) memcpy(cString, reinterpret_cast(ba_string.data()), cStringSize); } -CString::CString(const CString &cstr) +CString::CString(const CString& cstr) { cStringSize = cstr.cStringSize; cString = new uint8_t[cStringSize](); diff --git a/src/core/indexedlist.h b/src/core/indexedlist.h index 84c8768d5..f3c7b83a5 100644 --- a/src/core/indexedlist.h +++ b/src/core/indexedlist.h @@ -1,8 +1,8 @@ #ifndef INDEXEDLIST_H #define INDEXEDLIST_H -#include #include +#include template class IndexedList @@ -19,28 +19,22 @@ public: template bool contains(cmp_type i) { - return std::find_if(begin(), end(), [i](T& t) - { - return static_cast(t) == i; - }) != end(); + return std::find_if(begin(), end(), [i](T& t) { return static_cast(t) == i; }) + != end(); } template void remove(cmp_type i) { - v.erase(std::remove_if(begin(), end(), [i](T& t) - { - return static_cast(t) == i; - }), end()); + v.erase(std::remove_if(begin(), end(), [i](T& t) { return static_cast(t) == i; }), + end()); } template T& operator[](cmp_type i) { - iterator it = std::find_if(begin(), end(), [i](T& t) - { - return static_cast(t) == i; - }); + iterator it = + std::find_if(begin(), end(), [i](T& t) { return static_cast(t) == i; }); if (it == end()) it = insert({}); diff --git a/src/core/recursivesignalblocker.cpp b/src/core/recursivesignalblocker.cpp index ccbf128cd..1c960ae22 100644 --- a/src/core/recursivesignalblocker.cpp +++ b/src/core/recursivesignalblocker.cpp @@ -53,8 +53,7 @@ void RecursiveSignalBlocker::recursiveBlock(QObject* object) { mBlockers << new QSignalBlocker(object); - for (QObject* child : object->children()) - { + for (QObject* child : object->children()) { recursiveBlock(child); } } diff --git a/src/core/toxcall.cpp b/src/core/toxcall.cpp index 505aace68..3a8d03798 100644 --- a/src/core/toxcall.cpp +++ b/src/core/toxcall.cpp @@ -1,5 +1,5 @@ -#include "src/audio/audio.h" #include "src/core/toxcall.h" +#include "src/audio/audio.h" #include "src/core/coreav.h" #include "src/persistence/settings.h" #include "src/video/camerasource.h" @@ -12,7 +12,8 @@ * @brief Could be a friendNum or groupNum, must uniquely identify the call. Do not modify! * * @var bool ToxCall::inactive - * @brief True while we're not participating. (stopped group call, ringing but hasn't started yet, ...) + * @brief True while we're not participating. (stopped group call, ringing but hasn't started yet, + * ...) * * @var bool ToxFriendCall::videoEnabled * @brief True if our user asked for a video call, sending and recieving. @@ -30,17 +31,23 @@ using namespace std; ToxCall::ToxCall(uint32_t CallId) - : callId{CallId}, alSource{0}, - inactive{true}, muteMic{false}, muteVol{false} + : callId{CallId} + , alSource{0} + , inactive{true} + , muteMic{false} + , muteVol{false} { Audio& audio = Audio::getInstance(); audio.subscribeInput(); audio.subscribeOutput(alSource); } -ToxCall::ToxCall(ToxCall&& other) noexcept - : audioInConn{other.audioInConn}, callId{other.callId}, alSource{other.alSource}, - inactive{other.inactive}, muteMic{other.muteMic}, muteVol{other.muteVol} +ToxCall::ToxCall(ToxCall&& other) noexcept : audioInConn{other.audioInConn}, + callId{other.callId}, + alSource{other.alSource}, + inactive{other.inactive}, + muteMic{other.muteMic}, + muteVol{other.muteVol} { other.audioInConn = QMetaObject::Connection(); other.callId = numeric_limits::max(); @@ -81,15 +88,13 @@ ToxCall& ToxCall::operator=(ToxCall&& other) noexcept void ToxFriendCall::startTimeout() { - if (!timeoutTimer) - { + if (!timeoutTimer) { timeoutTimer = new QTimer(); // We might move, so we need copies of members. CoreAV won't move while we're alive CoreAV* avCopy = av; auto callIdCopy = callId; - QObject::connect(timeoutTimer, &QTimer::timeout, [avCopy, callIdCopy](){ - avCopy->timeoutCall(callIdCopy); - }); + QObject::connect(timeoutTimer, &QTimer::timeout, + [avCopy, callIdCopy]() { avCopy->timeoutCall(callIdCopy); }); } if (!timeoutTimer->isActive()) @@ -107,19 +112,21 @@ void ToxFriendCall::stopTimeout() } ToxFriendCall::ToxFriendCall(uint32_t FriendNum, bool VideoEnabled, CoreAV& av) - : ToxCall(FriendNum), - videoEnabled{VideoEnabled}, nullVideoBitrate{false}, videoSource{nullptr}, - state{static_cast(0)}, - av{&av}, timeoutTimer{nullptr} + : ToxCall(FriendNum) + , videoEnabled{VideoEnabled} + , nullVideoBitrate{false} + , videoSource{nullptr} + , state{static_cast(0)} + , av{&av} + , timeoutTimer{nullptr} { audioInConn = QObject::connect(&Audio::getInstance(), &Audio::frameAvailable, - [&av,FriendNum](const int16_t *pcm, size_t samples, uint8_t chans, uint32_t rate) - { - av.sendCallAudio(FriendNum, pcm, samples, chans, rate); - }); + [&av, FriendNum](const int16_t* pcm, size_t samples, + uint8_t chans, uint32_t rate) { + av.sendCallAudio(FriendNum, pcm, samples, chans, rate); + }); - if (videoEnabled) - { + if (videoEnabled) { videoSource = new CoreVideoSource; CameraSource& source = CameraSource::getInstance(); @@ -127,15 +134,20 @@ ToxFriendCall::ToxFriendCall(uint32_t FriendNum, bool VideoEnabled, CoreAV& av) source.open(); source.subscribe(); QObject::connect(&source, &VideoSource::frameAvailable, - [FriendNum,&av](shared_ptr frame){av.sendCallVideo(FriendNum,frame);}); + [FriendNum, &av](shared_ptr frame) { + av.sendCallVideo(FriendNum, frame); + }); } } ToxFriendCall::ToxFriendCall(ToxFriendCall&& other) noexcept : ToxCall(move(other)), - videoEnabled{other.videoEnabled}, nullVideoBitrate{other.nullVideoBitrate}, - videoSource{other.videoSource}, state{other.state}, - av{other.av}, timeoutTimer{other.timeoutTimer} + videoEnabled{other.videoEnabled}, + nullVideoBitrate{other.nullVideoBitrate}, + videoSource{other.videoSource}, + state{other.state}, + av{other.av}, + timeoutTimer{other.timeoutTimer} { other.videoEnabled = false; other.videoSource = nullptr; @@ -147,14 +159,14 @@ ToxFriendCall::~ToxFriendCall() if (timeoutTimer) delete timeoutTimer; - if (videoEnabled) - { + if (videoEnabled) { // This destructor could be running in a toxav callback while holding toxav locks. - // If the CameraSource thread calls toxav *_send_frame, we might deadlock the toxav and CameraSource locks, - // so we unsuscribe asynchronously, it's fine if the webcam takes a couple milliseconds more to poweroff. - QtConcurrent::run([](){CameraSource::getInstance().unsubscribe();}); - if (videoSource) - { + // If the CameraSource thread calls toxav *_send_frame, we might deadlock the toxav and + // CameraSource locks, + // so we unsuscribe asynchronously, it's fine if the webcam takes a couple milliseconds more + // to poweroff. + QtConcurrent::run([]() { CameraSource::getInstance().unsubscribe(); }); + if (videoSource) { videoSource->setDeleteOnClose(true); videoSource = nullptr; } @@ -163,7 +175,7 @@ ToxFriendCall::~ToxFriendCall() ToxFriendCall& ToxFriendCall::operator=(ToxFriendCall&& other) noexcept { - ToxCall::operator =(move(other)); + ToxCall::operator=(move(other)); videoEnabled = other.videoEnabled; other.videoEnabled = false; videoSource = other.videoSource; @@ -177,21 +189,21 @@ ToxFriendCall& ToxFriendCall::operator=(ToxFriendCall&& other) noexcept return *this; } -ToxGroupCall::ToxGroupCall(int GroupNum, CoreAV &av) +ToxGroupCall::ToxGroupCall(int GroupNum, CoreAV& av) : ToxCall(static_cast(GroupNum)) { - static_assert(numeric_limits::max() >= numeric_limits::max(), - "The callId must be able to represent any group number, change its type if needed"); + static_assert( + numeric_limits::max() >= numeric_limits::max(), + "The callId must be able to represent any group number, change its type if needed"); audioInConn = QObject::connect(&Audio::getInstance(), &Audio::frameAvailable, - [&av,GroupNum](const int16_t *pcm, size_t samples, uint8_t chans, uint32_t rate) - { - av.sendGroupCallAudio(GroupNum, pcm, samples, chans, rate); - }); + [&av, GroupNum](const int16_t* pcm, size_t samples, + uint8_t chans, uint32_t rate) { + av.sendGroupCallAudio(GroupNum, pcm, samples, chans, rate); + }); } -ToxGroupCall::ToxGroupCall(ToxGroupCall&& other) noexcept - : ToxCall(move(other)) +ToxGroupCall::ToxGroupCall(ToxGroupCall&& other) noexcept : ToxCall(move(other)) { } @@ -199,15 +211,14 @@ ToxGroupCall::~ToxGroupCall() { Audio& audio = Audio::getInstance(); - for(quint32 v : peers) - { + for (quint32 v : peers) { audio.unsubscribeOutput(v); } } -ToxGroupCall &ToxGroupCall::operator=(ToxGroupCall &&other) noexcept +ToxGroupCall& ToxGroupCall::operator=(ToxGroupCall&& other) noexcept { - ToxCall::operator =(move(other)); + ToxCall::operator=(move(other)); return *this; } diff --git a/src/core/toxcall.h b/src/core/toxcall.h index a11ef43e1..3be4b9b19 100644 --- a/src/core/toxcall.h +++ b/src/core/toxcall.h @@ -1,10 +1,10 @@ #ifndef TOXCALL_H #define TOXCALL_H -#include -#include -#include #include +#include +#include +#include #include "src/core/indexedlist.h" @@ -18,19 +18,23 @@ class CoreAV; struct ToxCall { protected: - ToxCall() = default; - explicit ToxCall(uint32_t CallId); - ~ToxCall(); -public: - ToxCall(const ToxCall& other) = delete; - ToxCall(ToxCall&& other) noexcept; + ToxCall() = default; + explicit ToxCall(uint32_t CallId); + ~ToxCall(); - inline operator int() {return callId;} - ToxCall& operator=(const ToxCall& other) = delete; - ToxCall& operator=(ToxCall&& other) noexcept; +public: + ToxCall(const ToxCall& other) = delete; + ToxCall(ToxCall&& other) noexcept; + + inline operator int() + { + return callId; + } + ToxCall& operator=(const ToxCall& other) = delete; + ToxCall& operator=(ToxCall&& other) noexcept; protected: - QMetaObject::Connection audioInConn; + QMetaObject::Connection audioInConn; public: uint32_t callId; @@ -80,4 +84,3 @@ struct ToxGroupCall : public ToxCall }; #endif // TOXCALL_H - diff --git a/src/core/toxencrypt.cpp b/src/core/toxencrypt.cpp index 22a6fb9c2..b7ecee6b4 100644 --- a/src/core/toxencrypt.cpp +++ b/src/core/toxencrypt.cpp @@ -20,10 +20,10 @@ #include "toxencrypt.h" #include -#include #include #include #include +#include // functions for nice debug output static QString getKeyDerivationError(TOX_ERR_KEY_DERIVATION error); @@ -51,9 +51,10 @@ ToxEncrypt::~ToxEncrypt() * @brief Constructs a ToxEncrypt object from a Tox_Pass_Key. * @param key Derived key to use for encryption and decryption. */ -ToxEncrypt::ToxEncrypt(Tox_Pass_Key* key) : -passKey{key} -{} +ToxEncrypt::ToxEncrypt(Tox_Pass_Key* key) + : passKey{key} +{ +} /** * @brief Gets the minimum number of bytes needed for isEncrypted() @@ -72,8 +73,7 @@ int ToxEncrypt::getMinBytes() */ bool ToxEncrypt::isEncrypted(const QByteArray& ciphertext) { - if (ciphertext.length() < TOX_PASS_ENCRYPTION_EXTRA_LENGTH) - { + if (ciphertext.length() < TOX_PASS_ENCRYPTION_EXTRA_LENGTH) { return false; } @@ -89,8 +89,7 @@ bool ToxEncrypt::isEncrypted(const QByteArray& ciphertext) */ QByteArray ToxEncrypt::encryptPass(const QString& password, const QByteArray& plaintext) { - if (password.length() == 0) - { + if (password.length() == 0) { qWarning() << "Empty password supplied, probably not what you intended."; } @@ -103,8 +102,7 @@ QByteArray ToxEncrypt::encryptPass(const QString& password, const QByteArray& pl static_cast(pass.size()), reinterpret_cast(ciphertext.data()), &error); - if (error != TOX_ERR_ENCRYPTION_OK) - { + if (error != TOX_ERR_ENCRYPTION_OK) { qCritical() << getEncryptionError(error); return QByteArray{}; } @@ -121,14 +119,12 @@ QByteArray ToxEncrypt::encryptPass(const QString& password, const QByteArray& pl */ QByteArray ToxEncrypt::decryptPass(const QString& password, const QByteArray& ciphertext) { - if (!isEncrypted(ciphertext)) - { + if (!isEncrypted(ciphertext)) { qWarning() << "The data was not encrypted using this module or it's corrupted."; return QByteArray{}; } - if (password.length() == 0) - { + if (password.length() == 0) { qDebug() << "Empty password supplied, probably not what you intended."; } @@ -138,11 +134,10 @@ QByteArray ToxEncrypt::decryptPass(const QString& password, const QByteArray& ci tox_pass_decrypt(reinterpret_cast(ciphertext.constData()), static_cast(ciphertext.size()), reinterpret_cast(pass.constData()), - static_cast(pass.size()), - reinterpret_cast(plaintext.data()), &error); + static_cast(pass.size()), reinterpret_cast(plaintext.data()), + &error); - if (error != TOX_ERR_DECRYPTION_OK) - { + if (error != TOX_ERR_DECRYPTION_OK) { qWarning() << getDecryptionError(error); return QByteArray{}; } @@ -166,8 +161,7 @@ std::unique_ptr ToxEncrypt::makeToxEncrypt(const QString& password) tox_pass_key_derive(passKey, reinterpret_cast(pass.constData()), static_cast(pass.length()), &error); - if (error != TOX_ERR_KEY_DERIVATION_OK) - { + if (error != TOX_ERR_KEY_DERIVATION_OK) { tox_pass_key_free(passKey); qCritical() << getKeyDerivationError(error); return std::unique_ptr{}; @@ -187,8 +181,7 @@ std::unique_ptr ToxEncrypt::makeToxEncrypt(const QString& password) */ std::unique_ptr ToxEncrypt::makeToxEncrypt(const QString& password, const QByteArray& toxSave) { - if (!isEncrypted(toxSave)) - { + if (!isEncrypted(toxSave)) { qWarning() << "The data was not encrypted using this module or it's corrupted."; return std::unique_ptr{}; } @@ -197,8 +190,7 @@ std::unique_ptr ToxEncrypt::makeToxEncrypt(const QString& password, uint8_t salt[TOX_PASS_SALT_LENGTH]; tox_get_salt(reinterpret_cast(toxSave.constData()), salt, &saltError); - if (saltError != TOX_ERR_GET_SALT_OK) - { + if (saltError != TOX_ERR_GET_SALT_OK) { qWarning() << getSaltError(saltError); return std::unique_ptr{}; } @@ -207,10 +199,9 @@ std::unique_ptr ToxEncrypt::makeToxEncrypt(const QString& password, QByteArray pass = password.toUtf8(); TOX_ERR_KEY_DERIVATION keyError; tox_pass_key_derive_with_salt(passKey, reinterpret_cast(pass.constData()), - static_cast(pass.length()), salt, &keyError); + static_cast(pass.length()), salt, &keyError); - if (keyError != TOX_ERR_KEY_DERIVATION_OK) - { + if (keyError != TOX_ERR_KEY_DERIVATION_OK) { tox_pass_key_free(passKey); qWarning() << getKeyDerivationError(keyError); return std::unique_ptr{}; @@ -226,21 +217,18 @@ std::unique_ptr ToxEncrypt::makeToxEncrypt(const QString& password, */ QByteArray ToxEncrypt::encrypt(const QByteArray& plaintext) const { - if (!passKey) - { + if (!passKey) { qCritical() << "The passKey is invalid."; return QByteArray{}; } QByteArray ciphertext(plaintext.length() + TOX_PASS_ENCRYPTION_EXTRA_LENGTH, 0x00); TOX_ERR_ENCRYPTION error; - tox_pass_key_encrypt(passKey, - reinterpret_cast(plaintext.constData()), + tox_pass_key_encrypt(passKey, reinterpret_cast(plaintext.constData()), static_cast(plaintext.size()), reinterpret_cast(ciphertext.data()), &error); - if (error != TOX_ERR_ENCRYPTION_OK) - { + if (error != TOX_ERR_ENCRYPTION_OK) { qCritical() << getEncryptionError(error); return QByteArray{}; } @@ -256,21 +244,18 @@ QByteArray ToxEncrypt::encrypt(const QByteArray& plaintext) const */ QByteArray ToxEncrypt::decrypt(const QByteArray& ciphertext) const { - if (!isEncrypted(ciphertext)) - { + if (!isEncrypted(ciphertext)) { qWarning() << "The data was not encrypted using this module or it's corrupted."; return QByteArray{}; } QByteArray plaintext(ciphertext.length() - TOX_PASS_ENCRYPTION_EXTRA_LENGTH, 0x00); TOX_ERR_DECRYPTION error; - tox_pass_key_decrypt(passKey, - reinterpret_cast(ciphertext.constData()), + tox_pass_key_decrypt(passKey, reinterpret_cast(ciphertext.constData()), static_cast(ciphertext.size()), reinterpret_cast(plaintext.data()), &error); - if (error != TOX_ERR_DECRYPTION_OK) - { + if (error != TOX_ERR_DECRYPTION_OK) { qWarning() << getDecryptionError(error); return QByteArray{}; } @@ -285,14 +270,15 @@ QByteArray ToxEncrypt::decrypt(const QByteArray& ciphertext) const */ QString getKeyDerivationError(TOX_ERR_KEY_DERIVATION error) { - switch(error) - { + switch (error) { case TOX_ERR_KEY_DERIVATION_OK: return QStringLiteral("The function returned successfully."); case TOX_ERR_KEY_DERIVATION_NULL: - return QStringLiteral("One of the arguments to the function was NULL when it was not expected."); + return QStringLiteral( + "One of the arguments to the function was NULL when it was not expected."); case TOX_ERR_KEY_DERIVATION_FAILED: - return QStringLiteral("The crypto lib was unable to derive a key from the given passphrase."); + return QStringLiteral( + "The crypto lib was unable to derive a key from the given passphrase."); default: return QStringLiteral("Unknown key derivation error."); } @@ -305,14 +291,15 @@ QString getKeyDerivationError(TOX_ERR_KEY_DERIVATION error) */ QString getEncryptionError(TOX_ERR_ENCRYPTION error) { - switch(error) - { + switch (error) { case TOX_ERR_ENCRYPTION_OK: return QStringLiteral("The function returned successfully."); case TOX_ERR_ENCRYPTION_NULL: - return QStringLiteral("One of the arguments to the function was NULL when it was not expected."); + return QStringLiteral( + "One of the arguments to the function was NULL when it was not expected."); case TOX_ERR_ENCRYPTION_KEY_DERIVATION_FAILED: - return QStringLiteral("The crypto lib was unable to derive a key from the given passphrase."); + return QStringLiteral( + "The crypto lib was unable to derive a key from the given passphrase."); case TOX_ERR_ENCRYPTION_FAILED: return QStringLiteral("The encryption itself failed."); default: @@ -327,14 +314,15 @@ QString getEncryptionError(TOX_ERR_ENCRYPTION error) */ QString getDecryptionError(TOX_ERR_DECRYPTION error) { - switch(error) - { + switch (error) { case TOX_ERR_DECRYPTION_OK: return QStringLiteral("The function returned successfully."); case TOX_ERR_DECRYPTION_NULL: - return QStringLiteral("One of the arguments to the function was NULL when it was not expected."); + return QStringLiteral( + "One of the arguments to the function was NULL when it was not expected."); case TOX_ERR_DECRYPTION_INVALID_LENGTH: - return QStringLiteral("The input data was shorter than TOX_PASS_ENCRYPTION_EXTRA_LENGTH bytes."); + return QStringLiteral( + "The input data was shorter than TOX_PASS_ENCRYPTION_EXTRA_LENGTH bytes."); case TOX_ERR_DECRYPTION_BAD_FORMAT: return QStringLiteral("The input data is missing the magic number or is corrupted."); default: @@ -349,12 +337,12 @@ QString getDecryptionError(TOX_ERR_DECRYPTION error) */ QString getSaltError(TOX_ERR_GET_SALT error) { - switch(error) - { + switch (error) { case TOX_ERR_GET_SALT_OK: return QStringLiteral("The function returned successfully."); case TOX_ERR_GET_SALT_NULL: - return QStringLiteral("One of the arguments to the function was NULL when it was not expected."); + return QStringLiteral( + "One of the arguments to the function was NULL when it was not expected."); case TOX_ERR_GET_SALT_BAD_FORMAT: return QStringLiteral("The input data is missing the magic number or is corrupted."); default: diff --git a/src/core/toxencrypt.h b/src/core/toxencrypt.h index 6281efb12..6ab4e6fa8 100644 --- a/src/core/toxencrypt.h +++ b/src/core/toxencrypt.h @@ -17,8 +17,8 @@ along with qTox. If not, see . */ -#include #include +#include #ifndef TOXENCRYPT_H #define TOXENCRYPT_H @@ -40,7 +40,8 @@ public: static QByteArray encryptPass(const QString& password, const QByteArray& plaintext); static QByteArray decryptPass(const QString& password, const QByteArray& ciphertext); static std::unique_ptr makeToxEncrypt(const QString& password); - static std::unique_ptr makeToxEncrypt(const QString& password, const QByteArray& toxSave); + static std::unique_ptr makeToxEncrypt(const QString& password, + const QByteArray& toxSave); QByteArray encrypt(const QByteArray& plaintext) const; QByteArray decrypt(const QByteArray& ciphertext) const; diff --git a/src/core/toxid.cpp b/src/core/toxid.cpp index 217b907fa..a67dfe593 100644 --- a/src/core/toxid.cpp +++ b/src/core/toxid.cpp @@ -24,17 +24,17 @@ #include -#include #include +#include // Tox doesn't publicly define these -#define NOSPAM_BYTES 4 -#define CHECKSUM_BYTES 2 +#define NOSPAM_BYTES 4 +#define CHECKSUM_BYTES 2 -#define PUBLIC_KEY_HEX_CHARS (2*TOX_PUBLIC_KEY_SIZE) -#define NOSPAM_HEX_CHARS (2*NOSPAM_BYTES) -#define CHECKSUM_HEX_CHARS (2*CHECKSUM_BYTES) -#define TOXID_HEX_CHARS (2*TOX_ADDRESS_SIZE) +#define PUBLIC_KEY_HEX_CHARS (2 * TOX_PUBLIC_KEY_SIZE) +#define NOSPAM_HEX_CHARS (2 * NOSPAM_BYTES) +#define CHECKSUM_HEX_CHARS (2 * CHECKSUM_BYTES) +#define TOXID_HEX_CHARS (2 * TOX_ADDRESS_SIZE) const QRegularExpression ToxId::ToxIdRegEx(QString("(^|\\s)[A-Fa-f0-9]{%1}($|\\s)").arg(TOXID_HEX_CHARS)); @@ -59,16 +59,18 @@ const QRegularExpression ToxId::ToxIdRegEx(QString("(^|\\s)[A-Fa-f0-9]{%1}($|\\s * @brief The default constructor. Creates an empty Tox ID. */ ToxId::ToxId() -: toxId() -{} + : toxId() +{ +} /** * @brief The copy constructor. * @param other ToxId to copy */ ToxId::ToxId(const ToxId& other) -: toxId(other.toxId) -{} + : toxId(other.toxId) +{ +} /** * @brief Create a Tox ID from a QString. @@ -82,17 +84,12 @@ ToxId::ToxId(const ToxId& other) ToxId::ToxId(const QString& id) { // TODO: remove construction from PK only - if (isToxId(id)) - { + if (isToxId(id)) { toxId = QByteArray::fromHex(id.toLatin1()); - } - else if(id.length() >= PUBLIC_KEY_HEX_CHARS) - { + } else if (id.length() >= PUBLIC_KEY_HEX_CHARS) { toxId = QByteArray::fromHex(id.left(PUBLIC_KEY_HEX_CHARS).toLatin1()); - } - else - { - toxId = QByteArray(); // invalid id string + } else { + toxId = QByteArray(); // invalid id string } } @@ -123,7 +120,7 @@ ToxId::ToxId(const QByteArray& rawId) */ ToxId::ToxId(const uint8_t* rawId, int len) { - QByteArray tmpId(reinterpret_cast(rawId), len); + QByteArray tmpId(reinterpret_cast(rawId), len); constructToxId(tmpId); } @@ -131,18 +128,12 @@ ToxId::ToxId(const uint8_t* rawId, int len) void ToxId::constructToxId(const QByteArray& rawId) { // TODO: remove construction from PK only - if(rawId.length() == TOX_SECRET_KEY_SIZE) - { - toxId = QByteArray(rawId); // construct from PK only - } - else if (rawId.length() == TOX_ADDRESS_SIZE - && isToxId(rawId.toHex().toUpper())) - { - toxId = QByteArray(rawId); // construct from full toxid - } - else - { - toxId = QByteArray(); // invalid id + if (rawId.length() == TOX_SECRET_KEY_SIZE) { + toxId = QByteArray(rawId); // construct from PK only + } else if (rawId.length() == TOX_ADDRESS_SIZE && isToxId(rawId.toHex().toUpper())) { + toxId = QByteArray(rawId); // construct from full toxid + } else { + toxId = QByteArray(); // invalid id } } @@ -190,8 +181,7 @@ void ToxId::clear() */ const uint8_t* ToxId::getBytes() const { - if(isValid()) - { + if (isValid()) { return reinterpret_cast(toxId.constData()); } @@ -213,8 +203,7 @@ ToxPk ToxId::getPublicKey() const */ QString ToxId::getNoSpamString() const { - if(toxId.length() == TOX_ADDRESS_SIZE) - { + if (toxId.length() == TOX_ADDRESS_SIZE) { return toxId.mid(TOX_PUBLIC_KEY_SIZE, NOSPAM_BYTES).toHex().toUpper(); } @@ -249,8 +238,7 @@ bool ToxId::isToxId(const QString& id) */ bool ToxId::isValid() const { - if(toxId.length() != TOX_ADDRESS_SIZE) - { + if (toxId.length() != TOX_ADDRESS_SIZE) { return false; } @@ -260,8 +248,7 @@ bool ToxId::isValid() const QByteArray checksum = toxId.right(CHECKSUM_BYTES); QByteArray calculated(CHECKSUM_BYTES, 0x00); - for (int i = 0; i < size; i++) - { + for (int i = 0; i < size; i++) { calculated[i % 2] = calculated[i % 2] ^ data[i]; } diff --git a/src/core/toxid.h b/src/core/toxid.h index 7eef90ed4..a82f5bddb 100644 --- a/src/core/toxid.h +++ b/src/core/toxid.h @@ -23,9 +23,9 @@ #include "toxpk.h" -#include #include #include +#include class ToxId { @@ -43,7 +43,7 @@ public: bool isValid() const; static bool isValidToxId(const QString& id); - static bool isToxId(const QString &id); + static bool isToxId(const QString& id); const uint8_t* getBytes() const; QByteArray getToxId() const; ToxPk getPublicKey() const; diff --git a/src/core/toxpk.cpp b/src/core/toxpk.cpp index c368ce384..86ae0c1ee 100644 --- a/src/core/toxpk.cpp +++ b/src/core/toxpk.cpp @@ -14,16 +14,18 @@ * @brief The default constructor. Creates an empty Tox key. */ ToxPk::ToxPk() -: key() -{} + : key() +{ +} /** * @brief The copy constructor. * @param other ToxPk to copy */ ToxPk::ToxPk(const ToxPk& other) -: key(other.key) -{} + : key(other.key) +{ +} /** * @brief Constructs a ToxPk from bytes. @@ -32,12 +34,9 @@ ToxPk::ToxPk(const ToxPk& other) */ ToxPk::ToxPk(const QByteArray& rawId) { - if(rawId.length() == TOX_PUBLIC_KEY_SIZE) - { + if (rawId.length() == TOX_PUBLIC_KEY_SIZE) { key = QByteArray(rawId); - } - else - { + } else { key = QByteArray(); } } @@ -88,8 +87,7 @@ QString ToxPk::toString() const */ const uint8_t* ToxPk::getBytes() const { - if(key.isEmpty()) - { + if (key.isEmpty()) { return nullptr; } diff --git a/src/core/toxpk.h b/src/core/toxpk.h index b2265eda0..0e29029ea 100644 --- a/src/core/toxpk.h +++ b/src/core/toxpk.h @@ -1,9 +1,9 @@ #ifndef TOXPK_H #define TOXPK_H -#include #include #include +#include class ToxPk { @@ -21,6 +21,7 @@ public: bool isEmpty() const; static int getPkSize(); + private: QByteArray key; }; diff --git a/src/friend.cpp b/src/friend.cpp index f461901d1..fd5041329 100644 --- a/src/friend.cpp +++ b/src/friend.cpp @@ -23,8 +23,8 @@ #include "src/group.h" #include "src/grouplist.h" #include "src/nexus.h" -#include "src/persistence/settings.h" #include "src/persistence/profile.h" +#include "src/persistence/settings.h" #include "src/widget/form/chatform.h" Friend::Friend(uint32_t friendId, const ToxPk& friendPk) @@ -35,8 +35,7 @@ Friend::Friend(uint32_t friendId, const ToxPk& friendPk) , hasNewEvents(false) , friendStatus(Status::Offline) { - if (userName.isEmpty()) - { + if (userName.isEmpty()) { userName = friendPk.toString(); } @@ -55,8 +54,7 @@ Friend::~Friend() */ void Friend::loadHistory() { - if (Nexus::getProfile()->isHistoryEnabled()) - { + if (Nexus::getProfile()->isHistoryEnabled()) { chatForm->loadHistory(QDateTime::currentDateTime().addDays(-7), true); } @@ -65,13 +63,11 @@ void Friend::loadHistory() void Friend::setName(QString name) { - if (name.isEmpty()) - { + if (name.isEmpty()) { name = friendPk.toString(); } - if (userName != name) - { + if (userName != name) { userName = name; emit nameChanged(friendId, name); } @@ -79,8 +75,7 @@ void Friend::setName(QString name) void Friend::setAlias(QString alias) { - if (userAlias != alias) - { + if (userAlias != alias) { userAlias = alias; emit aliasChanged(friendId, alias); } @@ -88,8 +83,7 @@ void Friend::setAlias(QString alias) void Friend::setStatusMessage(QString message) { - if (statusMessage != message) - { + if (statusMessage != message) { statusMessage = message; emit statusMessageChanged(friendId, message); } @@ -102,8 +96,7 @@ QString Friend::getStatusMessage() QString Friend::getDisplayedName() const { - if (userAlias.isEmpty()) - { + if (userAlias.isEmpty()) { return userName; } @@ -137,8 +130,7 @@ bool Friend::getEventFlag() const void Friend::setStatus(Status s) { - if (friendStatus != s) - { + if (friendStatus != s) { friendStatus = s; emit statusChanged(friendId, friendStatus); } @@ -149,7 +141,7 @@ Status Friend::getStatus() const return friendStatus; } -ChatForm *Friend::getChatForm() +ChatForm* Friend::getChatForm() { return chatForm; } diff --git a/src/friend.h b/src/friend.h index afcb60ab9..5c5381152 100644 --- a/src/friend.h +++ b/src/friend.h @@ -20,10 +20,10 @@ #ifndef FRIEND_H #define FRIEND_H +#include "core/toxid.h" +#include "src/core/corestructs.h" #include #include -#include "src/core/corestructs.h" -#include "core/toxid.h" class FriendWidget; class ChatForm; @@ -56,7 +56,7 @@ public: void setStatus(Status s); Status getStatus() const; - ChatForm *getChatForm(); + ChatForm* getChatForm(); signals: // TODO: move signals to DB object diff --git a/src/friendlist.cpp b/src/friendlist.cpp index 1bc7919d2..8f6a1eca3 100644 --- a/src/friendlist.cpp +++ b/src/friendlist.cpp @@ -20,9 +20,9 @@ #include "friend.h" #include "friendlist.h" #include "src/persistence/settings.h" -#include #include #include +#include QHash FriendList::friendList; QHash FriendList::key2id; @@ -52,8 +52,7 @@ Friend* FriendList::findFriend(int friendId) void FriendList::removeFriend(int friendId, bool fake) { auto f_it = friendList.find(friendId); - if (f_it != friendList.end()) - { + if (f_it != friendList.end()) { if (!fake) Settings::getInstance().removeFriendSettings(f_it.value()->getPublicKey()); friendList.erase(f_it); @@ -70,8 +69,7 @@ void FriendList::clear() Friend* FriendList::findFriend(const ToxPk& friendPk) { auto id = key2id.find(friendPk.getKey()); - if (id != key2id.end()) - { + if (id != key2id.end()) { Friend* f = findFriend(*id); if (!f) return nullptr; diff --git a/src/friendlist.h b/src/friendlist.h index 2ccd807a9..4a7da6a78 100644 --- a/src/friendlist.h +++ b/src/friendlist.h @@ -20,8 +20,10 @@ #ifndef FRIENDLIST_H #define FRIENDLIST_H -template class QList; -template class QHash; +template +class QList; +template +class QHash; class Friend; class QByteArray; class ToxPk; diff --git a/src/group.cpp b/src/group.cpp index 5d9a7463e..8b53b8646 100644 --- a/src/group.cpp +++ b/src/group.cpp @@ -18,22 +18,24 @@ */ #include "group.h" -#include "widget/groupwidget.h" -#include "widget/form/groupchatform.h" -#include "friendlist.h" #include "friend.h" +#include "friendlist.h" #include "src/core/core.h" +#include "widget/form/groupchatform.h" +#include "widget/groupwidget.h" #include "widget/gui.h" #include #include Group::Group(int GroupId, QString Name, bool IsAvGroupchat) - : groupId(GroupId), nPeers{0}, avGroupchat{IsAvGroupchat} + : groupId(GroupId) + , nPeers{0} + , avGroupchat{IsAvGroupchat} { widget = new GroupWidget(groupId, Name); chatForm = new GroupChatForm(this); - //in groupchats, we only notify on messages containing your name <-- dumb + // in groupchats, we only notify on messages containing your name <-- dumb // sound notifications should be on all messages, but system popup notification // on naming is appropriate hasNewMessages = 0; @@ -54,13 +56,10 @@ void Group::updatePeer(int peerId, QString name) toxids[peerPk] = name; Friend* f = FriendList::findFriend(peerKey); - if (f != nullptr && f->hasAlias()) - { + if (f != nullptr && f->hasAlias()) { peers[peerId] = f->getDisplayedName(); toxids[peerPk] = f->getDisplayedName(); - } - else - { + } else { widget->onUserListChanged(); chatForm->onUserListChanged(); emit userListChanged(getGroupWidget()); @@ -88,8 +87,7 @@ void Group::regeneratePeerList() peers = core->getGroupPeerNames(groupId); toxids.clear(); nPeers = peers.size(); - for (int i = 0; i < nPeers; ++i) - { + for (int i = 0; i < nPeers; ++i) { ToxPk id = core->getGroupPeerPk(groupId, i); ToxPk self = core->getSelfId().getPublicKey(); if (id == self) @@ -98,11 +96,11 @@ void Group::regeneratePeerList() QByteArray peerPk = id.getKey(); toxids[peerPk] = peers[i]; if (toxids[peerPk].isEmpty()) - toxids[peerPk] = tr("", "Placeholder when someone's name in a group chat is empty"); + toxids[peerPk] = + tr("", "Placeholder when someone's name in a group chat is empty"); Friend* f = FriendList::findFriend(id); - if (f != nullptr && f->hasAlias()) - { + if (f != nullptr && f->hasAlias()) { peers[i] = f->getDisplayedName(); toxids[peerPk] = f->getDisplayedName(); } @@ -128,12 +126,12 @@ int Group::getPeersCount() const return nPeers; } -GroupChatForm *Group::getChatForm() +GroupChatForm* Group::getChatForm() { return chatForm; } -GroupWidget *Group::getGroupWidget() +GroupWidget* Group::getGroupWidget() { return widget; } @@ -168,7 +166,7 @@ int Group::getMentionedFlag() const return userWasMentioned; } -QString Group::resolveToxId(const ToxPk &id) const +QString Group::resolveToxId(const ToxPk& id) const { QByteArray key = id.getKey(); auto it = toxids.find(key); diff --git a/src/group.h b/src/group.h index 0bcc94710..ccb5aa17d 100644 --- a/src/group.h +++ b/src/group.h @@ -45,8 +45,8 @@ public: QStringList getPeerList() const; bool isSelfPeerNumber(int peernumber) const; - GroupChatForm *getChatForm(); - GroupWidget *getGroupWidget(); + GroupChatForm* getChatForm(); + GroupWidget* getGroupWidget(); void setEventFlag(int f); int getEventFlag() const; @@ -74,7 +74,6 @@ private: int nPeers; int selfPeerNum = -1; bool avGroupchat; - }; #endif // GROUP_H diff --git a/src/groupinvite.cpp b/src/groupinvite.cpp index ca632fb50..1b08c4c74 100644 --- a/src/groupinvite.cpp +++ b/src/groupinvite.cpp @@ -26,19 +26,17 @@ */ GroupInvite::GroupInvite(int32_t friendID, uint8_t inviteType, const QByteArray& data) - : friendId { friendID } - , type { inviteType } - , invite { data } - , date { QDateTime::currentDateTime() } + : friendId{friendID} + , type{inviteType} + , invite{data} + , date{QDateTime::currentDateTime()} { } -bool GroupInvite::operator ==(const GroupInvite& other) const +bool GroupInvite::operator==(const GroupInvite& other) const { - return friendId == other.friendId && - type == other.type && - invite == other.invite && - date == other.date; + return friendId == other.friendId && type == other.type && invite == other.invite + && date == other.date; } int32_t GroupInvite::getFriendId() const diff --git a/src/groupinvite.h b/src/groupinvite.h index b3ece245c..a4af08ceb 100644 --- a/src/groupinvite.h +++ b/src/groupinvite.h @@ -20,15 +20,15 @@ #ifndef GROUPINVITE_H #define GROUPINVITE_H -#include #include #include +#include class GroupInvite { public: GroupInvite(int32_t friendID, uint8_t inviteType, const QByteArray& data); - bool operator ==(const GroupInvite& other) const; + bool operator==(const GroupInvite& other) const; int32_t getFriendId() const; uint8_t getType() const; diff --git a/src/grouplist.cpp b/src/grouplist.cpp index 2b0680689..e2c5d4708 100644 --- a/src/grouplist.cpp +++ b/src/grouplist.cpp @@ -19,8 +19,8 @@ #include "grouplist.h" #include "group.h" -#include #include +#include QHash GroupList::groupList; @@ -48,13 +48,12 @@ Group* GroupList::findGroup(int groupId) void GroupList::removeGroup(int groupId, bool /*fake*/) { auto g_it = groupList.find(groupId); - if (g_it != groupList.end()) - { + if (g_it != groupList.end()) { groupList.erase(g_it); } } -QList GroupList::getAllGroups() +QList GroupList::getAllGroups() { QList res; diff --git a/src/grouplist.h b/src/grouplist.h index 71601d085..19a9170b5 100644 --- a/src/grouplist.h +++ b/src/grouplist.h @@ -20,8 +20,10 @@ #ifndef GROUPLIST_H #define GROUPLIST_H -template class QHash; -template class QList; +template +class QHash; +template +class QList; class Group; class QString; diff --git a/src/ipc.cpp b/src/ipc.cpp index 630db31ac..4dbed2fd0 100644 --- a/src/ipc.cpp +++ b/src/ipc.cpp @@ -51,33 +51,26 @@ IPC::IPC() // Every time it processes events it updates the global shared timestamp "lastProcessed" // If the timestamp isn't updated, that's a timeout and someone else can take ownership // This is a safety measure, in case one of the clients crashes - // If the owner exits normally, it can set the timestamp to 0 first to immediately give ownership + // If the owner exits normally, it can set the timestamp to 0 first to immediately give + // ownership std::default_random_engine randEngine((std::random_device())()); std::uniform_int_distribution distribution; globalId = distribution(randEngine); qDebug() << "Our global IPC ID is " << globalId; - if (globalMemory.create(sizeof(IPCMemory))) - { - if (globalMemory.lock()) - { + if (globalMemory.create(sizeof(IPCMemory))) { + if (globalMemory.lock()) { IPCMemory* mem = global(); memset(mem, 0, sizeof(IPCMemory)); mem->globalId = globalId; mem->lastProcessed = time(0); globalMemory.unlock(); - } - else - { + } else { qWarning() << "Couldn't lock to take ownership"; } - } - else if (globalMemory.attach()) - { + } else if (globalMemory.attach()) { qDebug() << "Attaching to the global shared memory"; - } - else - { + } else { qDebug() << "Failed to attach to the global shared memory, giving up"; return; // We won't be able to do any IPC without being attached, let's get outta here } @@ -87,10 +80,8 @@ IPC::IPC() IPC::~IPC() { - if (isCurrentOwner()) - { - if (globalMemory.lock()) - { + if (isCurrentOwner()) { + if (globalMemory.lock()) { global()->globalId = 0; globalMemory.unlock(); } @@ -113,7 +104,7 @@ IPC& IPC::getInstance() * @param dest Settings::getCurrentProfileId() or 0 (main instance, default). * @return Time the event finished. */ -time_t IPC::postEvent(const QString &name, const QByteArray& data, uint32_t dest) +time_t IPC::postEvent(const QString& name, const QByteArray& data, uint32_t dest) { QByteArray binName = name.toUtf8(); if (binName.length() > (int32_t)sizeof(IPCEvent::name)) @@ -122,20 +113,17 @@ time_t IPC::postEvent(const QString &name, const QByteArray& data, uint32_t dest if (data.length() > (int32_t)sizeof(IPCEvent::data)) return 0; - if (globalMemory.lock()) - { + if (globalMemory.lock()) { IPCEvent* evt = nullptr; IPCMemory* mem = global(); time_t result = 0; - for (uint32_t i = 0; !evt && i < EVENT_QUEUE_SIZE; ++i) - { + for (uint32_t i = 0; !evt && i < EVENT_QUEUE_SIZE; ++i) { if (mem->events[i].posted == 0) evt = &mem->events[i]; } - if (evt) - { + if (evt) { memset(evt, 0, sizeof(IPCEvent)); memcpy(evt->name, binName.constData(), binName.length()); memcpy(evt->data, data.constData(), data.length()); @@ -146,8 +134,7 @@ time_t IPC::postEvent(const QString &name, const QByteArray& data, uint32_t dest } globalMemory.unlock(); return result; - } - else + } else qDebug() << "Failed to lock in postEvent()"; return 0; @@ -155,11 +142,9 @@ time_t IPC::postEvent(const QString &name, const QByteArray& data, uint32_t dest bool IPC::isCurrentOwner() { - if (globalMemory.lock()) - { + if (globalMemory.lock()) { void* data = globalMemory.data(); - if (!data) - { + if (!data) { qWarning() << "isCurrentOwner failed to access the memory, returning false"; globalMemory.unlock(); return false; @@ -167,9 +152,7 @@ bool IPC::isCurrentOwner() bool isOwner = ((*(uint64_t*)data) == globalId); globalMemory.unlock(); return isOwner; - } - else - { + } else { qWarning() << "isCurrentOwner failed to lock, returning false"; return false; } @@ -179,7 +162,7 @@ bool IPC::isCurrentOwner() * @brief Register a handler for an IPC event * @param handler The handler callback. Should not block for more than a second, at worst */ -void IPC::registerEventHandler(const QString &name, IPCEventHandler handler) +void IPC::registerEventHandler(const QString& name, IPCEventHandler handler) { eventHandlers[name] = handler; } @@ -187,15 +170,11 @@ void IPC::registerEventHandler(const QString &name, IPCEventHandler handler) bool IPC::isEventAccepted(time_t time) { bool result = false; - if (globalMemory.lock()) - { - if (difftime(global()->lastProcessed, time) > 0) - { + if (globalMemory.lock()) { + if (difftime(global()->lastProcessed, time) > 0) { IPCMemory* mem = global(); - for (uint32_t i = 0; i < EVENT_QUEUE_SIZE; ++i) - { - if (mem->events[i].posted == time && mem->events[i].processed) - { + for (uint32_t i = 0; i < EVENT_QUEUE_SIZE; ++i) { + if (mem->events[i].posted == time && mem->events[i].processed) { result = mem->events[i].accepted; break; } @@ -206,7 +185,7 @@ bool IPC::isEventAccepted(time_t time) return result; } -bool IPC::waitUntilAccepted(time_t postTime, int32_t timeout/*=-1*/) +bool IPC::waitUntilAccepted(time_t postTime, int32_t timeout /*=-1*/) { bool result = false; time_t start = time(0); @@ -226,23 +205,22 @@ bool IPC::waitUntilAccepted(time_t postTime, int32_t timeout/*=-1*/) * @brief Only called when global memory IS LOCKED. * @return nullptr if no evnts present, IPC event otherwise */ -IPC::IPCEvent *IPC::fetchEvent() +IPC::IPCEvent* IPC::fetchEvent() { IPCMemory* mem = global(); - for (uint32_t i = 0; i < EVENT_QUEUE_SIZE; ++i) - { + for (uint32_t i = 0; i < EVENT_QUEUE_SIZE; ++i) { IPCEvent* evt = &mem->events[i]; // Garbage-collect events that were not processed in EVENT_GC_TIMEOUT // and events that were processed and EVENT_GC_TIMEOUT passed after // so sending instance has time to react to those events. - if ((evt->processed && difftime(time(0), evt->processed) > EVENT_GC_TIMEOUT) || - (!evt->processed && difftime(time(0), evt->posted) > EVENT_GC_TIMEOUT)) + if ((evt->processed && difftime(time(0), evt->processed) > EVENT_GC_TIMEOUT) + || (!evt->processed && difftime(time(0), evt->posted) > EVENT_GC_TIMEOUT)) memset(evt, 0, sizeof(IPCEvent)); if (evt->posted && !evt->processed && evt->sender != getpid() - && (evt->dest == Settings::getInstance().getCurrentProfileId() - || (evt->dest == 0 && isCurrentOwner()))) + && (evt->dest == Settings::getInstance().getCurrentProfileId() + || (evt->dest == 0 && isCurrentOwner()))) return evt; } @@ -255,10 +233,8 @@ bool IPC::runEventHandler(IPCEventHandler handler, const QByteArray& arg) if (QThread::currentThread() == qApp->thread()) result = handler(arg); else - QMetaObject::invokeMethod(this, "runEventHandler", - Qt::BlockingQueuedConnection, - Q_RETURN_ARG(bool, result), - Q_ARG(IPCEventHandler, handler), + QMetaObject::invokeMethod(this, "runEventHandler", Qt::BlockingQueuedConnection, + Q_RETURN_ARG(bool, result), Q_ARG(IPCEventHandler, handler), Q_ARG(const QByteArray&, arg)); return result; @@ -266,21 +242,18 @@ bool IPC::runEventHandler(IPCEventHandler handler, const QByteArray& arg) void IPC::processEvents() { - if (globalMemory.lock()) - { + if (globalMemory.lock()) { IPCMemory* mem = global(); - if (mem->globalId == globalId) - { + if (mem->globalId == globalId) { // We're the owner, let's process those events mem->lastProcessed = time(0); - } - else - { - // Only the owner processes events. But if the previous owner's dead, we can take ownership now - if (difftime(time(0), mem->lastProcessed) >= OWNERSHIP_TIMEOUT_S) - { - qDebug() << "Previous owner timed out, taking ownership" << mem->globalId << "->" << globalId; + } else { + // Only the owner processes events. But if the previous owner's dead, we can take + // ownership now + if (difftime(time(0), mem->lastProcessed) >= OWNERSHIP_TIMEOUT_S) { + qDebug() << "Previous owner timed out, taking ownership" << mem->globalId << "->" + << globalId; // Ignore events that were not meant for this instance memset(mem, 0, sizeof(IPCMemory)); mem->globalId = globalId; @@ -289,27 +262,22 @@ void IPC::processEvents() // Non-main instance is limited to events destined for specific profile it runs } - while (IPCEvent* evt = fetchEvent()) - { + while (IPCEvent* evt = fetchEvent()) { QString name = QString::fromUtf8(evt->name); auto it = eventHandlers.find(name); - if (it != eventHandlers.end()) - { + if (it != eventHandlers.end()) { qDebug() << "Processing event: " << name << ":" << evt->posted << "=" << evt->accepted; evt->accepted = runEventHandler(it.value(), evt->data); - if (evt->dest == 0) - { - // Global events should be processed only by instance that accepted event. Otherwise global + if (evt->dest == 0) { + // Global events should be processed only by instance that accepted event. + // Otherwise global // event would be consumed by very first instance that gets to check it. if (evt->accepted) evt->processed = time(0); - } - else - { + } else { evt->processed = time(0); } } - } globalMemory.unlock(); @@ -317,7 +285,7 @@ void IPC::processEvents() timer.start(); } -IPC::IPCMemory *IPC::global() +IPC::IPCMemory* IPC::global() { return static_cast(globalMemory.data()); } diff --git a/src/ipc.h b/src/ipc.h index 3aca38e78..e59fb907d 100644 --- a/src/ipc.h +++ b/src/ipc.h @@ -21,15 +21,15 @@ #ifndef IPC_H #define IPC_H -#include -#include #include #include #include #include #include +#include +#include -using IPCEventHandler = std::function; +using IPCEventHandler = std::function; #define IPC_PROTOCOL_VERSION "2" @@ -37,6 +37,7 @@ class IPC : public QObject { Q_OBJECT IPC(); + protected: static const int EVENT_TIMER_MS = 1000; static const int EVENT_GC_TIMEOUT = 5; @@ -69,11 +70,11 @@ public: IPCEvent events[IPC::EVENT_QUEUE_SIZE]; }; - time_t postEvent(const QString& name, const QByteArray &data=QByteArray(), uint32_t dest=0); + time_t postEvent(const QString& name, const QByteArray& data = QByteArray(), uint32_t dest = 0); bool isCurrentOwner(); void registerEventHandler(const QString& name, IPCEventHandler handler); bool isEventAccepted(time_t time); - bool waitUntilAccepted(time_t time, int32_t timeout=-1); + bool waitUntilAccepted(time_t time, int32_t timeout = -1); protected slots: void processEvents(); diff --git a/src/main.cpp b/src/main.cpp index bc6dbe892..20ad1743c 100644 --- a/src/main.cpp +++ b/src/main.cpp @@ -17,25 +17,25 @@ along with qTox. If not, see . */ -#include "widget/widget.h" #include "persistence/settings.h" -#include "src/nexus.h" #include "src/ipc.h" -#include "src/net/toxuri.h" #include "src/net/autoupdate.h" -#include "src/persistence/toxsave.h" +#include "src/net/toxuri.h" +#include "src/nexus.h" #include "src/persistence/profile.h" +#include "src/persistence/toxsave.h" +#include "src/video/camerasource.h" #include "src/widget/loginscreen.h" #include "src/widget/translator.h" -#include "src/video/camerasource.h" +#include "widget/widget.h" #include #include #include #include #include #include -#include #include +#include #include #include @@ -47,7 +47,8 @@ #ifdef LOG_TO_FILE static QAtomicPointer logFileFile = nullptr; -static QList* logBuffer = new QList(); //Store log messages until log file opened +static QList* logBuffer = + new QList(); // Store log messages until log file opened QMutex* logBufferMutex = new QMutex(); #endif @@ -55,7 +56,7 @@ void logMessageHandler(QtMsgType type, const QMessageLogContext& ctxt, const QSt { // Silence qWarning spam due to bug in QTextBrowser (trying to open a file for base64 images) if (ctxt.function == QString("virtual bool QFSFileEngine::open(QIODevice::OpenMode)") - && msg == QString("QFSFileEngine::open: No file name specified")) + && msg == QString("QFSFileEngine::open: No file name specified")) return; QString file = ctxt.file; @@ -63,31 +64,29 @@ void logMessageHandler(QtMsgType type, const QMessageLogContext& ctxt, const QSt // nullptr in release builds. QString path = QString(__FILE__); path = path.left(path.lastIndexOf('/') + 1); - if (file.startsWith(path)) - { + if (file.startsWith(path)) { file = file.mid(path.length()); } // Time should be in UTC to save user privacy on log sharing QTime time = QDateTime::currentDateTime().toUTC().time(); - QString LogMsg = QString("[%1 UTC] %2:%3 : ") - .arg(time.toString("HH:mm:ss.zzz")).arg(file).arg(ctxt.line); - switch (type) - { - case QtDebugMsg: - LogMsg += "Debug"; - break; - case QtWarningMsg: - LogMsg += "Warning"; - break; - case QtCriticalMsg: - LogMsg += "Critical"; - break; - case QtFatalMsg: - LogMsg += "Fatal"; - break; - default: - break; + QString LogMsg = + QString("[%1 UTC] %2:%3 : ").arg(time.toString("HH:mm:ss.zzz")).arg(file).arg(ctxt.line); + switch (type) { + case QtDebugMsg: + LogMsg += "Debug"; + break; + case QtWarningMsg: + LogMsg += "Warning"; + break; + case QtCriticalMsg: + LogMsg += "Critical"; + break; + case QtFatalMsg: + LogMsg += "Fatal"; + break; + default: + break; } LogMsg += ": " + msg + "\n"; @@ -95,25 +94,21 @@ void logMessageHandler(QtMsgType type, const QMessageLogContext& ctxt, const QSt fwrite(LogMsgBytes.constData(), 1, LogMsgBytes.size(), stderr); #ifdef LOG_TO_FILE - FILE * logFilePtr = logFileFile.load(); // atomically load the file pointer - if (!logFilePtr) - { + FILE* logFilePtr = logFileFile.load(); // atomically load the file pointer + if (!logFilePtr) { logBufferMutex->lock(); if (logBuffer) logBuffer->append(LogMsgBytes); logBufferMutex->unlock(); - } - else - { + } else { logBufferMutex->lock(); - if (logBuffer) - { + if (logBuffer) { // empty logBuffer to file foreach (QByteArray msg, *logBuffer) fwrite(msg.constData(), 1, msg.size(), logFilePtr); - delete logBuffer; // no longer needed + delete logBuffer; // no longer needed logBuffer = nullptr; } logBufferMutex->unlock(); @@ -124,7 +119,7 @@ void logMessageHandler(QtMsgType type, const QMessageLogContext& ctxt, const QSt #endif } -int main(int argc, char *argv[]) +int main(int argc, char* argv[]) { #if (QT_VERSION >= QT_VERSION_CHECK(5, 6, 0)) @@ -141,7 +136,7 @@ int main(int argc, char *argv[]) #if defined(Q_OS_OSX) // TODO: Add setting to enable this feature. - //osx::moveToAppFolder(); + // osx::moveToAppFolder(); osx::migrateProfiles(); #endif @@ -151,11 +146,14 @@ int main(int argc, char *argv[]) // Process arguments QCommandLineParser parser; - parser.setApplicationDescription("qTox, version: " + QString(GIT_VERSION) + "\nBuilt: " + __TIME__ + " " + __DATE__); + parser.setApplicationDescription("qTox, version: " + QString(GIT_VERSION) + "\nBuilt: " + + __TIME__ + " " + __DATE__); parser.addHelpOption(); parser.addVersionOption(); parser.addPositionalArgument("uri", QObject::tr("Tox URI to parse")); - parser.addOption(QCommandLineOption("p", QObject::tr("Starts new instance and loads specified profile."), QObject::tr("profile"))); + parser.addOption( + QCommandLineOption("p", QObject::tr("Starts new instance and loads specified profile."), + QObject::tr("profile"))); parser.process(a); IPC& ipc = IPC::getInstance(); @@ -171,18 +169,17 @@ int main(int argc, char *argv[]) QDir(logFileDir).mkpath("."); QString logfile = logFileDir + "qtox.log"; - FILE * mainLogFilePtr = fopen(logfile.toLocal8Bit().constData(), "a"); + FILE* mainLogFilePtr = fopen(logfile.toLocal8Bit().constData(), "a"); // Trim log file if over 1MB - if (QFileInfo(logfile).size() > 1000000) - { + if (QFileInfo(logfile).size() > 1000000) { qDebug() << "Log file over 1MB, rotating..."; // close old logfile (need for windows) if (mainLogFilePtr) fclose(mainLogFilePtr); - QDir dir (logFileDir); + QDir dir(logFileDir); // Check if log.1 already exists, and if so, delete it if (dir.remove(logFileDir + "qtox.log.1")) @@ -200,7 +197,7 @@ int main(int argc, char *argv[]) if (!mainLogFilePtr) qCritical() << "Couldn't open logfile" << logfile; - logFileFile.store(mainLogFilePtr); // atomically set the logFile + logFileFile.store(mainLogFilePtr); // atomically set the logFile #endif // Windows platform plugins DLL hell fix @@ -213,7 +210,7 @@ int main(int argc, char *argv[]) // Install Unicode 6.1 supporting font QFontDatabase::addApplicationFont("://DejaVuSans.ttf"); - // Check whether we have an update waiting to be installed +// Check whether we have an update waiting to be installed #if AUTOUPDATE_ENABLED if (AutoUpdater::isLocalUpdateReady()) AutoUpdater::installLocalUpdate(); ///< NORETURN @@ -229,64 +226,49 @@ int main(int argc, char *argv[]) uint32_t ipcDest = 0; QString eventType, firstParam; - if (parser.isSet("p")) - { + if (parser.isSet("p")) { profileName = parser.value("p"); - if (!Profile::exists(profileName)) - { - qCritical() << "-p profile" << profileName + ".tox" << "doesn't exist"; + if (!Profile::exists(profileName)) { + qCritical() << "-p profile" << profileName + ".tox" + << "doesn't exist"; return EXIT_FAILURE; } ipcDest = Settings::makeProfileId(profileName); autoLogin = true; - } - else - { + } else { profileName = Settings::getInstance().getCurrentProfile(); } - if (parser.positionalArguments().size() == 0) - { + if (parser.positionalArguments().size() == 0) { eventType = "activate"; - } - else - { + } else { firstParam = parser.positionalArguments()[0]; - // Tox URIs. If there's already another qTox instance running, we ask it to handle the URI and we exit + // Tox URIs. If there's already another qTox instance running, we ask it to handle the URI + // and we exit // Otherwise we start a new qTox instance and process it ourselves - if (firstParam.startsWith("tox:")) - { + if (firstParam.startsWith("tox:")) { eventType = "uri"; - } - else if (firstParam.endsWith(".tox")) - { + } else if (firstParam.endsWith(".tox")) { eventType = "save"; - } - else - { + } else { qCritical() << "Invalid argument"; return EXIT_FAILURE; } } - if (!ipc.isCurrentOwner()) - { + if (!ipc.isCurrentOwner()) { time_t event = ipc.postEvent(eventType, firstParam.toUtf8(), ipcDest); // If someone else processed it, we're done here, no need to actually start qTox - if (ipc.waitUntilAccepted(event, 2)) - { + if (ipc.waitUntilAccepted(event, 2)) { qDebug() << "Event" << eventType << "was handled by other client."; return EXIT_SUCCESS; } } // Autologin - if (autoLogin) - { - if (Profile::exists(profileName)) - { - if (!Profile::isEncrypted(profileName)) - { + if (autoLogin) { + if (Profile::exists(profileName)) { + if (!Profile::isEncrypted(profileName)) { Profile* profile = Profile::loadProfile(profileName); if (profile) Nexus::getInstance().setProfile(profile); @@ -315,7 +297,7 @@ int main(int argc, char *argv[]) qDebug() << "Clean exit with status" << errorcode; #ifdef LOG_TO_FILE - logFileFile.store(nullptr); // atomically disable logging to file + logFileFile.store(nullptr); // atomically disable logging to file fclose(mainLogFilePtr); #endif return errorcode; diff --git a/src/net/autoupdate.cpp b/src/net/autoupdate.cpp index af8b35c5a..92f59c32b 100644 --- a/src/net/autoupdate.cpp +++ b/src/net/autoupdate.cpp @@ -18,32 +18,34 @@ */ #include "src/net/autoupdate.h" +#include "src/nexus.h" #include "src/persistence/serialize.h" #include "src/persistence/settings.h" -#include "src/widget/widget.h" #include "src/widget/gui.h" -#include "src/nexus.h" -#include -#include +#include "src/widget/widget.h" #include -#include #include -#include -#include +#include #include #include +#include +#include +#include +#include #include #ifdef Q_OS_WIN -#include #include +#include #endif /** * @file autoupdate.cpp * - * For now we only support auto updates on Windows and OS X, although extending it is not a technical issue. - * Linux users are expected to use their package managers or update manually through official channels. + * For now we only support auto updates on Windows and OS X, although extending it is not a + * technical issue. + * Linux users are expected to use their package managers or update manually through official + * channels. */ #ifdef Q_OS_WIN @@ -55,22 +57,24 @@ const QString AutoUpdater::platform = "win32"; const QString AutoUpdater::updaterBin = "qtox-updater.exe"; const QString AutoUpdater::updateServer = "https://qtox-win.pkg.tox.chat"; -unsigned char AutoUpdater::key[crypto_sign_PUBLICKEYBYTES] = -{ - 0x20, 0x89, 0x39, 0xaa, 0x9a, 0xe8, 0xb5, 0x21, 0x0e, 0xac, 0x02, 0xa9, 0xc4, 0x92, 0xd9, 0xa2, - 0x17, 0x83, 0xbd, 0x78, 0x0a, 0xda, 0x33, 0xcd, 0xa5, 0xc6, 0x44, 0xc7, 0xfc, 0xed, 0x00, 0x13 -}; +unsigned char AutoUpdater::key[crypto_sign_PUBLICKEYBYTES] = {0x20, 0x89, 0x39, 0xaa, 0x9a, 0xe8, + 0xb5, 0x21, 0x0e, 0xac, 0x02, 0xa9, + 0xc4, 0x92, 0xd9, 0xa2, 0x17, 0x83, + 0xbd, 0x78, 0x0a, 0xda, 0x33, 0xcd, + 0xa5, 0xc6, 0x44, 0xc7, 0xfc, 0xed, + 0x00, 0x13}; #elif defined(Q_OS_OSX) const QString AutoUpdater::platform = "osx"; const QString AutoUpdater::updaterBin = "/Applications/qtox.app/Contents/MacOS/updater"; const QString AutoUpdater::updateServer = "https://dist-build.tox.im"; -unsigned char AutoUpdater::key[crypto_sign_PUBLICKEYBYTES] = -{ - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 -}; +unsigned char AutoUpdater::key[crypto_sign_PUBLICKEYBYTES] = {0x00, 0x00, 0x00, 0x00, 0x00, 0x00, + 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, + 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, + 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, + 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, + 0x00, 0x00}; #else const QString AutoUpdater::platform; @@ -122,9 +126,12 @@ unsigned char AutoUpdater::key[crypto_sign_PUBLICKEYBYTES]; * @brief No, we can't just make the QString atomic */ -const QString AutoUpdater::checkURI = AutoUpdater::updateServer+"/qtox/"+AutoUpdater::platform+"/version"; -const QString AutoUpdater::flistURI = AutoUpdater::updateServer+"/qtox/"+AutoUpdater::platform+"/flist"; -const QString AutoUpdater::filesURI = AutoUpdater::updateServer+"/qtox/"+AutoUpdater::platform+"/files/"; +const QString AutoUpdater::checkURI = + AutoUpdater::updateServer + "/qtox/" + AutoUpdater::platform + "/version"; +const QString AutoUpdater::flistURI = + AutoUpdater::updateServer + "/qtox/" + AutoUpdater::platform + "/flist"; +const QString AutoUpdater::filesURI = + AutoUpdater::updateServer + "/qtox/" + AutoUpdater::platform + "/files/"; std::atomic_bool AutoUpdater::abortFlag{false}; std::atomic_bool AutoUpdater::isDownloadingUpdate{false}; std::atomic AutoUpdater::progressValue{0}; @@ -149,7 +156,8 @@ bool AutoUpdater::isUpdateAvailable() if (isDownloadingUpdate) return false; - QString updaterPath = updaterBin.startsWith('/') ? updaterBin : qApp->applicationDirPath()+'/'+updaterBin; + QString updaterPath = + updaterBin.startsWith('/') ? updaterBin : qApp->applicationDirPath() + '/' + updaterBin; if (!QFile::exists(updaterPath)) return false; @@ -175,18 +183,16 @@ AutoUpdater::VersionInfo AutoUpdater::getUpdateVersion() if (abortFlag) return versionInfo; - QNetworkAccessManager *manager = new QNetworkAccessManager; + QNetworkAccessManager* manager = new QNetworkAccessManager; manager->setProxy(Settings::getInstance().getProxy()); QNetworkReply* reply = manager->get(QNetworkRequest(QUrl(checkURI))); - while (!reply->isFinished()) - { + while (!reply->isFinished()) { if (abortFlag) return versionInfo; qApp->processEvents(); } - if (reply->error() != QNetworkReply::NoError) - { + if (reply->error() != QNetworkReply::NoError) { qWarning() << "getUpdateVersion: network error: " + reply->errorString(); reply->deleteLater(); manager->deleteLater(); @@ -196,12 +202,11 @@ AutoUpdater::VersionInfo AutoUpdater::getUpdateVersion() QByteArray data = reply->readAll(); reply->deleteLater(); manager->deleteLater(); - if (data.size() < (int)(1+crypto_sign_BYTES)) + if (data.size() < (int)(1 + crypto_sign_BYTES)) return versionInfo; // Check updater protocol version - if ((int)data[0] != '3') - { + if ((int)data[0] != '3') { qWarning() << "getUpdateVersion: Bad version " << (uint8_t)data[0]; return versionInfo; } @@ -209,20 +214,19 @@ AutoUpdater::VersionInfo AutoUpdater::getUpdateVersion() // Check the signature QByteArray sigData = data.mid(1, crypto_sign_BYTES); unsigned char* sig = (unsigned char*)sigData.data(); - QByteArray msgData = data.mid(1+crypto_sign_BYTES); + QByteArray msgData = data.mid(1 + crypto_sign_BYTES); unsigned char* msg = (unsigned char*)msgData.data(); - if (crypto_sign_verify_detached(sig, msg, msgData.size(), key) != 0) - { - qCritical() << "getUpdateVersion: RECEIVED FORGED VERSION FILE FROM "< AutoUpdater::parseFlist(QByteArray flistData) { QList flist; - if (flistData.isEmpty()) - { + if (flistData.isEmpty()) { qWarning() << "parseflist: Empty data"; return flist; } // Check version - if (flistData[0] != '1') - { - qWarning() << "parseflist: Bad version "<<(uint8_t)flistData[0]; + if (flistData[0] != '1') { + qWarning() << "parseflist: Bad version " << (uint8_t)flistData[0]; return flist; } flistData = flistData.mid(1); // Check signature - if (flistData.size() < (int)(crypto_sign_BYTES)) - { + if (flistData.size() < (int)(crypto_sign_BYTES)) { qWarning() << "parseflist: Truncated data"; return flist; - } - else - { + } else { QByteArray msgData = flistData.mid(crypto_sign_BYTES); unsigned char* msg = (unsigned char*)msgData.data(); - if (crypto_sign_verify_detached((unsigned char*)flistData.data(), msg, msgData.size(), key) != 0) - { + if (crypto_sign_verify_detached((unsigned char*)flistData.data(), msg, msgData.size(), key) + != 0) { qCritical() << "parseflist: FORGED FLIST FILE"; return flist; } @@ -269,8 +268,7 @@ QList AutoUpdater::parseFlist(QByteArray flistData) } // Parse. We assume no errors handling needed since the signature is valid. - while (!flistData.isEmpty()) - { + while (!flistData.isEmpty()) { UpdateFileMeta newFile; memcpy(newFile.sig, flistData.data(), crypto_sign_BYTES); @@ -300,18 +298,16 @@ QByteArray AutoUpdater::getUpdateFlist() { QByteArray flist; - QNetworkAccessManager *manager = new QNetworkAccessManager; + QNetworkAccessManager* manager = new QNetworkAccessManager; manager->setProxy(Settings::getInstance().getProxy()); QNetworkReply* reply = manager->get(QNetworkRequest(QUrl(flistURI))); - while (!reply->isFinished()) - { + while (!reply->isFinished()) { if (abortFlag) return flist; qApp->processEvents(); } - if (reply->error() != QNetworkReply::NoError) - { + if (reply->error() != QNetworkReply::NoError) { qWarning() << "getUpdateFlist: network error: " + reply->errorString(); reply->deleteLater(); manager->deleteLater(); @@ -349,7 +345,7 @@ QList AutoUpdater::genUpdateDiff(QListapplicationDirPath(); - QFile file(appDir+QDir::separator()+fileMeta.installpath); + QFile file(appDir + QDir::separator() + fileMeta.installpath); if (!file.open(QIODevice::ReadOnly)) return false; @@ -363,31 +359,31 @@ bool AutoUpdater::isUpToDate(AutoUpdater::UpdateFileMeta fileMeta) /** * @brief Tries to fetch the file from the update server. - * @note Note that a file with an empty but non-null QByteArray is not an error, merely a file of size 0. + * @note Note that a file with an empty but non-null QByteArray is not an error, merely a file of + * size 0. * @note Will try to follow qTox's proxy settings, may block and processEvents. * @param fileMeta Meta data fo file to update. - * @param progressCallback Callback function, which will connected with QNetworkReply::downloadProgress + * @param progressCallback Callback function, which will connected with + * QNetworkReply::downloadProgress * @return A file with a null QByteArray on error. */ AutoUpdater::UpdateFile AutoUpdater::getUpdateFile(UpdateFileMeta fileMeta, - std::function progressCallback) + std::function progressCallback) { UpdateFile file; file.metadata = fileMeta; - QNetworkAccessManager *manager = new QNetworkAccessManager; + QNetworkAccessManager* manager = new QNetworkAccessManager; manager->setProxy(Settings::getInstance().getProxy()); - QNetworkReply* reply = manager->get(QNetworkRequest(QUrl(filesURI+fileMeta.id))); + QNetworkReply* reply = manager->get(QNetworkRequest(QUrl(filesURI + fileMeta.id))); QObject::connect(reply, &QNetworkReply::downloadProgress, progressCallback); - while (!reply->isFinished()) - { + while (!reply->isFinished()) { if (abortFlag) return file; qApp->processEvents(); } - if (reply->error() != QNetworkReply::NoError) - { + if (reply->error() != QNetworkReply::NoError) { qWarning() << "getUpdateFile: network error: " + reply->errorString(); reply->deleteLater(); manager->deleteLater(); @@ -413,7 +409,7 @@ bool AutoUpdater::downloadUpdate() return false; bool expectFalse = false; - if (!isDownloadingUpdate.compare_exchange_strong(expectFalse,true)) + if (!isDownloadingUpdate.compare_exchange_strong(expectFalse, true)) return false; // Get a list of files to update @@ -424,8 +420,7 @@ bool AutoUpdater::downloadUpdate() // Progress progressValue = 0; - if (abortFlag) - { + if (abortFlag) { isDownloadingUpdate = false; return false; } @@ -438,17 +433,15 @@ bool AutoUpdater::downloadUpdate() if (!updateDir.exists()) QDir().mkdir(updateDirStr); updateDir = QDir(updateDirStr); - if (!updateDir.exists()) - { + if (!updateDir.exists()) { qWarning() << "downloadUpdate: Can't create update directory, aborting..."; isDownloadingUpdate = false; return false; } // Write the new flist for the updater - QFile newFlistFile(updateDirStr+"flist"); - if (!newFlistFile.open(QIODevice::WriteOnly | QIODevice::Truncate)) - { + QFile newFlistFile(updateDirStr + "flist"); + if (!newFlistFile.open(QIODevice::WriteOnly | QIODevice::Truncate)) { qWarning() << "downloadUpdate: Can't save new flist file, aborting..."; isDownloadingUpdate = false; return false; @@ -459,25 +452,21 @@ bool AutoUpdater::downloadUpdate() progressValue = 1; // Download and write each new file - for (UpdateFileMeta fileMeta : diff) - { - float initialProgress = progressValue, step = 99./diff.size(); - auto stepProgressCallback = [&](int current, int total) - { - progressValue = initialProgress + step * (float)current/total; + for (UpdateFileMeta fileMeta : diff) { + float initialProgress = progressValue, step = 99. / diff.size(); + auto stepProgressCallback = [&](int current, int total) { + progressValue = initialProgress + step * (float)current / total; }; - if (abortFlag) - { + if (abortFlag) { isDownloadingUpdate = false; return false; } // Skip files we already have - QFile fileFile(updateDirStr+fileMeta.installpath); - if (fileFile.open(QIODevice::ReadOnly) && fileFile.size() == (qint64)fileMeta.size) - { - qDebug() << "Skipping already downloaded file '" + fileMeta.installpath+ "'"; + QFile fileFile(updateDirStr + fileMeta.installpath); + if (fileFile.open(QIODevice::ReadOnly) && fileFile.size() == (qint64)fileMeta.size) { + qDebug() << "Skipping already downloaded file '" + fileMeta.installpath + "'"; progressValue = initialProgress + step; continue; } @@ -486,7 +475,7 @@ bool AutoUpdater::downloadUpdate() qDebug() << "Downloading '" + fileMeta.installpath + "' ..."; // Create subdirs if necessary - QString fileDirStr{QFileInfo(updateDirStr+fileMeta.installpath).absolutePath()}; + QString fileDirStr{QFileInfo(updateDirStr + fileMeta.installpath).absolutePath()}; if (!QDir(fileDirStr).exists()) QDir().mkpath(fileDirStr); @@ -494,23 +483,21 @@ bool AutoUpdater::downloadUpdate() UpdateFile file = getUpdateFile(fileMeta, stepProgressCallback); if (abortFlag) goto fail; - if (file.data.isNull()) - { + if (file.data.isNull()) { qCritical() << "downloadUpdate: Error downloading a file, aborting..."; goto fail; } // Check signature if (crypto_sign_verify_detached(file.metadata.sig, (unsigned char*)file.data.data(), - file.data.size(), key) != 0) - { + file.data.size(), key) + != 0) { qCritical() << "downloadUpdate: RECEIVED FORGED FILE, aborting..."; goto fail; } // Save - if (!fileFile.open(QIODevice::WriteOnly | QIODevice::Truncate)) - { + if (!fileFile.open(QIODevice::WriteOnly | QIODevice::Truncate)) { qCritical() << "downloadUpdate: Can't save new update file, aborting..."; goto fail; } @@ -556,7 +543,7 @@ bool AutoUpdater::isLocalUpdateReady() return false; // Check that we have a flist and generate a diff - QFile updateFlistFile(updateDirStr+"flist"); + QFile updateFlistFile(updateDirStr + "flist"); if (!updateFlistFile.open(QIODevice::ReadOnly)) return false; QByteArray updateFlistData = updateFlistFile.readAll(); @@ -566,12 +553,11 @@ bool AutoUpdater::isLocalUpdateReady() QList diff = genUpdateDiff(updateFlist); // Check that we have every file - for (UpdateFileMeta fileMeta : diff) - { - if (!QFile::exists(updateDirStr+fileMeta.installpath)) + for (UpdateFileMeta fileMeta : diff) { + if (!QFile::exists(updateDirStr + fileMeta.installpath)) return false; - QFile f(updateDirStr+fileMeta.installpath); + QFile f(updateDirStr + fileMeta.installpath); if (f.size() != (int64_t)fileMeta.size) return false; } @@ -591,8 +577,7 @@ void AutoUpdater::installLocalUpdate() qDebug() << "About to start the qTox updater to install a local update"; // Prepare to delete the update if we fail so we don't fail again. - auto failExit = []() - { + auto failExit = []() { qCritical() << "Failed to start the qTox updater, removing the update and exiting"; QString updateDirStr = Settings::getInstance().getSettingsDirPath() + "/update/"; QDir(updateDirStr).removeRecursively(); @@ -603,17 +588,16 @@ void AutoUpdater::installLocalUpdate() if (platform.isEmpty()) failExit(); - // Workaround QTBUG-7645 - // QProcess fails silently when elevation is required instead of showing a UAC prompt on Win7/Vista +// Workaround QTBUG-7645 +// QProcess fails silently when elevation is required instead of showing a UAC prompt on Win7/Vista #ifdef Q_OS_WIN QString modulePath = qApp->applicationDirPath().replace('/', '\\'); - HINSTANCE result = ::ShellExecuteW(0, L"open", updaterBin.toStdWString().c_str(), - 0, modulePath.toStdWString().c_str(), SW_SHOWNORMAL); - if (result == (HINSTANCE)SE_ERR_ACCESSDENIED) - { + HINSTANCE result = ::ShellExecuteW(0, L"open", updaterBin.toStdWString().c_str(), 0, + modulePath.toStdWString().c_str(), SW_SHOWNORMAL); + if (result == (HINSTANCE)SE_ERR_ACCESSDENIED) { // Requesting elevation - result = ::ShellExecuteW(0, L"runas", updaterBin.toStdWString().c_str(), - 0, modulePath.toStdWString().c_str(), SW_SHOWNORMAL); + result = ::ShellExecuteW(0, L"runas", updaterBin.toStdWString().c_str(), 0, + modulePath.toStdWString().c_str(), SW_SHOWNORMAL); } if (result <= (HINSTANCE)32) failExit(); @@ -656,9 +640,7 @@ void AutoUpdater::checkUpdatesAsyncInteractiveWorker() QDir updateDir(updateDirStr); - - if (updateDir.exists() && QFile(updateDirStr+"flist").exists()) - { + if (updateDir.exists() && QFile(updateDirStr + "flist").exists()) { setProgressVersion(getUpdateVersion().versionString); downloadUpdate(); return; @@ -668,16 +650,17 @@ void AutoUpdater::checkUpdatesAsyncInteractiveWorker() QString contentText = QObject::tr("An update is available, do you want to download it now?\n" "It will be installed when qTox restarts."); if (!newVersion.versionString.isEmpty()) - contentText += "\n\n" + QObject::tr("Version %1, %2").arg(newVersion.versionString, - QDateTime::fromMSecsSinceEpoch(newVersion.timestamp*1000).toString()); + contentText += + "\n\n" + + QObject::tr("Version %1, %2") + .arg(newVersion.versionString, + QDateTime::fromMSecsSinceEpoch(newVersion.timestamp * 1000).toString()); if (abortFlag) return; - if (GUI::askQuestion(QObject::tr("Update", "The title of a message box"), - contentText, true, false)) - { + if (GUI::askQuestion(QObject::tr("Update", "The title of a message box"), contentText, true, false)) { setProgressVersion(newVersion.versionString); GUI::showUpdateDownloadProgress(); downloadUpdate(); diff --git a/src/net/autoupdate.h b/src/net/autoupdate.h index 0701ae3b0..aa6e7d71f 100644 --- a/src/net/autoupdate.h +++ b/src/net/autoupdate.h @@ -21,12 +21,12 @@ #ifndef AUTOUPDATE_H #define AUTOUPDATE_H -#include #include #include -#include +#include #include #include +#include #ifdef Q_OS_WIN #define AUTOUPDATE_ENABLED 1 @@ -48,8 +48,7 @@ public: bool operator==(const UpdateFileMeta& other) { - return (size == other.size - && id == other.id && installpath == other.installpath + return (size == other.size && id == other.id && installpath == other.installpath && memcmp(sig, other.sig, crypto_sign_BYTES) == 0); } }; @@ -72,7 +71,7 @@ public: static VersionInfo getUpdateVersion(); static bool downloadUpdate(); static bool isLocalUpdateReady(); - [[ noreturn ]] static void installLocalUpdate(); + [[noreturn]] static void installLocalUpdate(); static void abortUpdates(); static QString getProgressVersion(); static int getProgressValue(); @@ -82,7 +81,8 @@ protected: static QByteArray getUpdateFlist(); static QList genUpdateDiff(QList updateFlist); static bool isUpToDate(UpdateFileMeta file); - static UpdateFile getUpdateFile(UpdateFileMeta fileMeta, std::function progressCallback); + static UpdateFile getUpdateFile(UpdateFileMeta fileMeta, + std::function progressCallback); static void checkUpdatesAsyncInteractiveWorker(); static void setProgressVersion(QString version); diff --git a/src/net/avatarbroadcaster.cpp b/src/net/avatarbroadcaster.cpp index 1e187155c..3f3766e33 100644 --- a/src/net/avatarbroadcaster.cpp +++ b/src/net/avatarbroadcaster.cpp @@ -20,8 +20,8 @@ #include "avatarbroadcaster.h" #include "src/core/core.h" -#include #include +#include /** * @class AvatarBroadcaster @@ -35,8 +35,7 @@ QByteArray AvatarBroadcaster::avatarData; QMap AvatarBroadcaster::friendsSentTo; static QMetaObject::Connection autoBroadcastConn; -static auto autoBroadcast = [](uint32_t friendId, Status) -{ +static auto autoBroadcast = [](uint32_t friendId, Status) { AvatarBroadcaster::sendAvatarTo(friendId); }; @@ -79,5 +78,6 @@ void AvatarBroadcaster::enableAutoBroadcast(bool state) { QObject::disconnect(autoBroadcastConn); if (state) - autoBroadcastConn = QObject::connect(Core::getInstance(), &Core::friendStatusChanged, autoBroadcast); + autoBroadcastConn = + QObject::connect(Core::getInstance(), &Core::friendStatusChanged, autoBroadcast); } diff --git a/src/net/avatarbroadcaster.h b/src/net/avatarbroadcaster.h index 71a8f4008..94fe9593b 100644 --- a/src/net/avatarbroadcaster.h +++ b/src/net/avatarbroadcaster.h @@ -27,7 +27,7 @@ class AvatarBroadcaster { private: - AvatarBroadcaster()=delete; + AvatarBroadcaster() = delete; public: static void setAvatar(QByteArray data); diff --git a/src/net/toxme.cpp b/src/net/toxme.cpp index eedec8d37..eaf8625db 100644 --- a/src/net/toxme.cpp +++ b/src/net/toxme.cpp @@ -19,16 +19,16 @@ #include "toxme.h" #include "src/core/core.h" -#include -#include +#include #include #include -#include #include +#include +#include #include #include +#include #include -#include /** * @class Toxme @@ -38,7 +38,7 @@ * @note May process events while waiting for blocking calls */ -QByteArray Toxme::makeJsonRequest(QString url, QString json, QNetworkReply::NetworkError &error) +QByteArray Toxme::makeJsonRequest(QString url, QString json, QNetworkReply::NetworkError& error) { if (error) return QByteArray(); @@ -49,8 +49,7 @@ QByteArray Toxme::makeJsonRequest(QString url, QString json, QNetworkReply::Netw request.setHeader(QNetworkRequest::ContentTypeHeader, "application/json"); QNetworkReply* reply = netman.post(request, json.toUtf8()); - while (!reply->isFinished()) - { + while (!reply->isFinished()) { QThread::msleep(1); qApp->processEvents(); } @@ -60,7 +59,7 @@ QByteArray Toxme::makeJsonRequest(QString url, QString json, QNetworkReply::Netw return result; } -QByteArray Toxme::getServerPubkey(QString url, QNetworkReply::NetworkError &error) +QByteArray Toxme::getServerPubkey(QString url, QNetworkReply::NetworkError& error) { if (error) return QByteArray(); @@ -72,15 +71,13 @@ QByteArray Toxme::getServerPubkey(QString url, QNetworkReply::NetworkError &erro request.setHeader(QNetworkRequest::ContentTypeHeader, "application/json"); QNetworkReply* reply = netman.get(request); - while (!reply->isFinished()) - { + while (!reply->isFinished()) { QThread::msleep(1); qApp->processEvents(); } error = reply->error(); - if (error) - { + if (error) { qWarning() << "getServerPubkey: A network error occured:" << reply->errorString(); return QByteArray(); } @@ -94,12 +91,12 @@ QByteArray Toxme::getServerPubkey(QString url, QNetworkReply::NetworkError &erro int start = json.indexOf(pattern) + pattern.length(); int end = json.indexOf("\"", start); int pubkeySize = (end - start) / 2; - QString rawKey = json.mid(start, pubkeySize*2); + QString rawKey = json.mid(start, pubkeySize * 2); QByteArray key; // I think, exist more easy way to convert key to ByteArray for (int i = 0; i < pubkeySize; ++i) { - QString byte = rawKey.mid(i*2, 2); + QString byte = rawKey.mid(i * 2, 2); key[i] = byte.toInt(nullptr, 16); } @@ -109,8 +106,7 @@ QByteArray Toxme::getServerPubkey(QString url, QNetworkReply::NetworkError &erro QByteArray Toxme::prepareEncryptedJson(QString url, int action, QString payload) { QPair keypair = Core::getInstance()->getKeypair(); - if (keypair.first.isEmpty() || keypair.second.isEmpty()) - { + if (keypair.first.isEmpty() || keypair.second.isEmpty()) { qWarning() << "prepareEncryptedJson: Couldn't get our keypair, aborting"; return QByteArray(); } @@ -124,12 +120,12 @@ QByteArray Toxme::prepareEncryptedJson(QString url, int action, QString payload) randombytes((uint8_t*)nonce.data(), crypto_box_NONCEBYTES); QByteArray payloadData = payload.toUtf8(); - const size_t cypherlen = crypto_box_MACBYTES+payloadData.size(); + const size_t cypherlen = crypto_box_MACBYTES + payloadData.size(); unsigned char* payloadEnc = new unsigned char[cypherlen]; - int cryptResult = crypto_box_easy(payloadEnc,(uint8_t*)payloadData.data(),payloadData.size(), - (uint8_t*)nonce.data(),(unsigned char*)key.constData(), - (uint8_t*)keypair.second.data()); + int cryptResult = crypto_box_easy(payloadEnc, (uint8_t*)payloadData.data(), payloadData.size(), + (uint8_t*)nonce.data(), (unsigned char*)key.constData(), + (uint8_t*)keypair.second.data()); if (cryptResult != 0) // error return QByteArray(); @@ -137,10 +133,13 @@ QByteArray Toxme::prepareEncryptedJson(QString url, int action, QString payload) QByteArray payloadEncData(reinterpret_cast(payloadEnc), cypherlen); delete[] payloadEnc; - const QString json{"{\"action\":"+QString().setNum(action)+"," - "\"public_key\":\""+keypair.first.toHex()+"\"," - "\"encrypted\":\""+payloadEncData.toBase64()+"\"," - "\"nonce\":\""+nonce.toBase64()+"\"}"}; + const QString json{"{\"action\":" + QString().setNum(action) + "," + "\"public_key\":\"" + + keypair.first.toHex() + "\"," + "\"encrypted\":\"" + + payloadEncData.toBase64() + "\"," + "\"nonce\":\"" + + nonce.toBase64() + "\"}"}; return json.toUtf8(); } @@ -153,10 +152,10 @@ ToxId Toxme::lookup(QString address) { // JSON injection ? address = address.trimmed(); - address.replace('\\',"\\\\"); - address.replace('"',"\""); + address.replace('\\', "\\\\"); + address.replace('"', "\""); - const QString json{"{\"action\":3,\"name\":\""+address+"\"}"}; + const QString json{"{\"action\":3,\"name\":\"" + address + "\"}"}; QString apiUrl = "https://" + address.split(QLatin1Char('@')).last() + "/api"; QNetworkReply::NetworkError error = QNetworkReply::NoError; @@ -170,13 +169,13 @@ ToxId Toxme::lookup(QString address) if (index == -1) return ToxId(); - response = response.mid(index+pattern.size()); + response = response.mid(index + pattern.size()); const int idStart = response.indexOf('"'); if (idStart == -1) return ToxId(); - response = response.mid(idStart+1); + response = response.mid(idStart + 1); const int idEnd = response.indexOf('"'); if (idEnd == -1) @@ -199,10 +198,9 @@ Toxme::ExecCode Toxme::extractError(QString json) if (start == -1) return ServerError; - json = json.mid(start+pattern.size()); + json = json.mid(start + pattern.size()); int end = json.indexOf(","); - if (end == -1) - { + if (end == -1) { end = json.indexOf("}"); if (end == -1) return IncorrectResponse; @@ -227,16 +225,16 @@ Toxme::ExecCode Toxme::extractError(QString json) * @param[in] bio A short optional description of yourself if you want to publish your address. * @return password on success, else sets code parameter and returns an empty QString. */ -QString Toxme::createAddress(ExecCode &code, QString server, ToxId id, QString address, +QString Toxme::createAddress(ExecCode& code, QString server, ToxId id, QString address, bool keepPrivate, QString bio) { int privacy = keepPrivate ? 0 : 2; // JSON injection ? - bio.replace('\\',"\\\\"); - bio.replace('"',"\""); + bio.replace('\\', "\\\\"); + bio.replace('"', "\""); - address.replace('\\',"\\\\"); - address.replace('"',"\""); + address.replace('\\', "\\\\"); + address.replace('"', "\""); bio = bio.trimmed(); address = address.trimmed(); @@ -244,14 +242,18 @@ QString Toxme::createAddress(ExecCode &code, QString server, ToxId id, QString a if (!server.contains("://")) server = "https://" + server; - const QString payload{"{\"tox_id\":\""+id.toString()+"\"," - "\"name\":\""+address+"\"," - "\"privacy\":"+QString().setNum(privacy)+"," - "\"bio\":\""+bio+"\"," - "\"timestamp\":"+QString().setNum(time(0))+"}"}; + const QString payload{"{\"tox_id\":\"" + id.toString() + "\"," + "\"name\":\"" + + address + "\"," + "\"privacy\":" + + QString().setNum(privacy) + "," + "\"bio\":\"" + + bio + "\"," + "\"timestamp\":" + + QString().setNum(time(0)) + "}"}; QString pubkeyUrl = server + "/pk"; - QString apiUrl = server + "/api"; + QString apiUrl = server + "/api"; QNetworkReply::NetworkError error = QNetworkReply::NoError; QByteArray encrypted = prepareEncryptedJson(pubkeyUrl, 1, payload); QByteArray response = makeJsonRequest(apiUrl, encrypted, error); @@ -263,28 +265,26 @@ QString Toxme::createAddress(ExecCode &code, QString server, ToxId id, QString a return getPass(response, code); } -QString Toxme::getPass(QString json, ExecCode &code) { +QString Toxme::getPass(QString json, ExecCode& code) +{ static const QByteArray pattern{"password\":"}; json = json.remove(' '); const int start = json.indexOf(pattern); - if (start == -1) - { + if (start == -1) { code = NoPassword; return QString(); } - json = json.mid(start+pattern.size()); - if (json.startsWith("null")) - { + json = json.mid(start + pattern.size()); + if (json.startsWith("null")) { code = Updated; return QString(); } json = json.mid(1, json.length()); int end = json.indexOf("\""); - if (end == -1) - { + if (end == -1) { code = IncorrectResponse; return QString(); } @@ -302,8 +302,9 @@ QString Toxme::getPass(QString json, ExecCode &code) { */ Toxme::ExecCode Toxme::deleteAddress(QString server, ToxPk id) { - const QString payload{"{\"public_key\":\""+id.toString()+"\"," - "\"timestamp\":"+QString().setNum(time(0))+"}"}; + const QString payload{"{\"public_key\":\"" + id.toString() + "\"," + "\"timestamp\":" + + QString().setNum(time(0)) + "}"}; server = server.trimmed(); if (!server.contains("://")) diff --git a/src/net/toxme.h b/src/net/toxme.h index 2e821fc4f..4aeaf82d8 100644 --- a/src/net/toxme.h +++ b/src/net/toxme.h @@ -21,19 +21,20 @@ #ifndef TOXME_H #define TOXME_H -#include +#include "src/core/toxid.h" #include #include #include +#include #include -#include "src/core/toxid.h" class QNetworkAccessManager; class Toxme { public: - enum ExecCode { + enum ExecCode + { ExecError = -50, Ok = 0, Updated = 1, @@ -43,18 +44,18 @@ public: }; static ToxId lookup(QString address); - static QString createAddress(ExecCode &code, QString server, ToxId id, QString address, - bool keepPrivate=true, QString bio=QString()); + static QString createAddress(ExecCode& code, QString server, ToxId id, QString address, + bool keepPrivate = true, QString bio = QString()); static ExecCode deleteAddress(QString server, ToxPk id); static QString getErrorMessage(int errorCode); static QString translateErrorMessage(int errorCode); private: Toxme() = delete; - static QByteArray makeJsonRequest(QString url, QString json, QNetworkReply::NetworkError &error); + static QByteArray makeJsonRequest(QString url, QString json, QNetworkReply::NetworkError& error); static QByteArray prepareEncryptedJson(QString url, int action, QString payload); - static QByteArray getServerPubkey(QString url, QNetworkReply::NetworkError &error); - static QString getPass(QString json, ExecCode &code); + static QByteArray getServerPubkey(QString url, QNetworkReply::NetworkError& error); + static QString getPass(QString json, ExecCode& code); static ExecCode extractError(QString json); private: diff --git a/src/net/toxuri.cpp b/src/net/toxuri.cpp index 28c0c450b..d478974a9 100644 --- a/src/net/toxuri.cpp +++ b/src/net/toxuri.cpp @@ -19,21 +19,21 @@ #include "src/net/toxuri.h" -#include "src/net/toxme.h" -#include "src/widget/tool/friendrequestdialog.h" -#include "src/nexus.h" #include "src/core/core.h" +#include "src/net/toxme.h" +#include "src/nexus.h" +#include "src/widget/tool/friendrequestdialog.h" #include -#include -#include -#include +#include #include #include #include +#include #include #include -#include +#include #include +#include bool toxURIEventHandler(const QByteArray& eventData) { @@ -50,13 +50,12 @@ bool toxURIEventHandler(const QByteArray& eventData) * @param toxURI Tox URI to try to add. * @return True, if tox URI is correct, false otherwise. */ -bool handleToxURI(const QString &toxURI) +bool handleToxURI(const QString& toxURI) { Nexus& nexus = Nexus::getInstance(); Core* core = nexus.getCore(); - while (!core) - { + while (!core) { if (!nexus.isRunning()) return false; @@ -65,8 +64,7 @@ bool handleToxURI(const QString &toxURI) QThread::msleep(10); } - while (!core->isReady()) - { + while (!core->isReady()) { if (!nexus.isRunning()) return false; @@ -77,15 +75,13 @@ bool handleToxURI(const QString &toxURI) QString toxaddr = toxURI.mid(4); ToxId toxId(toxaddr); - if (!toxId.isValid()) - { + if (!toxId.isValid()) { toxId = Toxme::lookup(toxaddr); - if (!toxId.isValid()) - { - QMessageBox *messageBox = new QMessageBox(QMessageBox::Warning, - QMessageBox::tr("Couldn't add friend"), - QMessageBox::tr("%1 is not a valid Toxme address.") - .arg(toxaddr), QMessageBox::Ok, nullptr); + if (!toxId.isValid()) { + QMessageBox* messageBox = + new QMessageBox(QMessageBox::Warning, QMessageBox::tr("Couldn't add friend"), + QMessageBox::tr("%1 is not a valid Toxme address.").arg(toxaddr), + QMessageBox::Ok, nullptr); messageBox->setButtonText(QMessageBox::Ok, QMessageBox::tr("Ok")); QObject::connect(messageBox, &QMessageBox::finished, messageBox, &QMessageBox::deleteLater); messageBox->show(); @@ -93,25 +89,26 @@ bool handleToxURI(const QString &toxURI) } } - if (toxId == core->getSelfId()) - { - QMessageBox *messageBox = new QMessageBox(QMessageBox::Warning, - QMessageBox::tr("Couldn't add friend"), - QMessageBox::tr("You can't add yourself as a friend!", - "When trying to add your own Tox ID as friend"), - QMessageBox::Ok, nullptr); + if (toxId == core->getSelfId()) { + QMessageBox* messageBox = + new QMessageBox(QMessageBox::Warning, QMessageBox::tr("Couldn't add friend"), + QMessageBox::tr("You can't add yourself as a friend!", + "When trying to add your own Tox ID as friend"), + QMessageBox::Ok, nullptr); messageBox->setButtonText(QMessageBox::Ok, QMessageBox::tr("Ok")); QObject::connect(messageBox, &QMessageBox::finished, messageBox, &QMessageBox::deleteLater); messageBox->show(); return false; } - ToxURIDialog *dialog = new ToxURIDialog(0, toxaddr, QObject::tr("%1 here! Tox me maybe?", - "Default message in Tox URI friend requests. Write something appropriate!") - .arg(Nexus::getCore()->getUsername())); + ToxURIDialog* dialog = new ToxURIDialog( + 0, toxaddr, + QObject::tr("%1 here! Tox me maybe?", + "Default message in Tox URI friend requests. Write something appropriate!") + .arg(Nexus::getCore()->getUsername())); QObject::connect(dialog, &ToxURIDialog::finished, [=](int result) { if (result == QDialog::Accepted) - Core::getInstance()->requestFriendship(toxId, dialog->getRequestMessage()); + Core::getInstance()->requestFriendship(toxId, dialog->getRequestMessage()); dialog->deleteLater(); }); @@ -120,21 +117,21 @@ bool handleToxURI(const QString &toxURI) return true; } -ToxURIDialog::ToxURIDialog(QWidget* parent, const QString &userId, const QString &message) : - QDialog(parent) +ToxURIDialog::ToxURIDialog(QWidget* parent, const QString& userId, const QString& message) + : QDialog(parent) { setWindowFlags(windowFlags() & ~Qt::WindowContextHelpButtonHint); setWindowTitle(tr("Add a friend", "Title of the window to add a friend through Tox URI")); - QLabel *friendsLabel = new QLabel(tr("Do you want to add %1 as a friend?").arg(userId), this); - QLabel *userIdLabel = new QLabel(tr("User ID:"), this); - QLineEdit *userIdEdit = new QLineEdit(userId, this); + QLabel* friendsLabel = new QLabel(tr("Do you want to add %1 as a friend?").arg(userId), this); + QLabel* userIdLabel = new QLabel(tr("User ID:"), this); + QLineEdit* userIdEdit = new QLineEdit(userId, this); userIdEdit->setCursorPosition(0); userIdEdit->setReadOnly(true); - QLabel *messageLabel = new QLabel(tr("Friend request message:"), this); + QLabel* messageLabel = new QLabel(tr("Friend request message:"), this); messageEdit = new QPlainTextEdit(message, this); - QDialogButtonBox *buttonBox = new QDialogButtonBox(Qt::Horizontal, this); + QDialogButtonBox* buttonBox = new QDialogButtonBox(Qt::Horizontal, this); buttonBox->addButton(tr("Send", "Send a friend request"), QDialogButtonBox::AcceptRole); buttonBox->addButton(tr("Cancel", "Don't send a friend request"), QDialogButtonBox::RejectRole); @@ -142,7 +139,7 @@ ToxURIDialog::ToxURIDialog(QWidget* parent, const QString &userId, const QString connect(buttonBox, &QDialogButtonBox::accepted, this, &FriendRequestDialog::accept); connect(buttonBox, &QDialogButtonBox::rejected, this, &FriendRequestDialog::reject); - QVBoxLayout *layout = new QVBoxLayout(this); + QVBoxLayout* layout = new QVBoxLayout(this); layout->addWidget(friendsLabel); layout->addSpacing(12); diff --git a/src/net/toxuri.h b/src/net/toxuri.h index 0b0cb4a58..035e1b9ee 100644 --- a/src/net/toxuri.h +++ b/src/net/toxuri.h @@ -33,11 +33,11 @@ class ToxURIDialog : public QDialog { Q_OBJECT public: - explicit ToxURIDialog(QWidget* parent, const QString &userId, const QString &message); + explicit ToxURIDialog(QWidget* parent, const QString& userId, const QString& message); QString getRequestMessage(); private: - QPlainTextEdit *messageEdit; + QPlainTextEdit* messageEdit; }; #endif // TOXURI_H diff --git a/src/nexus.cpp b/src/nexus.cpp index 20a330be8..8b5f73d7a 100644 --- a/src/nexus.cpp +++ b/src/nexus.cpp @@ -19,28 +19,28 @@ #include "nexus.h" -#include "src/persistence/profile.h" +#include "persistence/settings.h" #include "src/core/core.h" #include "src/core/coreav.h" +#include "src/persistence/profile.h" #include "src/widget/widget.h" -#include "persistence/settings.h" #include "video/camerasource.h" #include "widget/gui.h" #include "widget/loginscreen.h" -#include -#include -#include -#include #include +#include +#include +#include +#include +#include #include #include -#include #ifdef Q_OS_MAC -#include -#include #include +#include #include +#include #endif /** @@ -55,13 +55,13 @@ Q_DECLARE_OPAQUE_POINTER(ToxAV*) static Nexus* nexus{nullptr}; -Nexus::Nexus(QObject *parent) : - QObject(parent), - profile{nullptr}, - widget{nullptr}, - loginScreen{nullptr}, - running{true}, - quitOnLastWindowClosed{true} +Nexus::Nexus(QObject* parent) + : QObject(parent) + , profile{nullptr} + , widget{nullptr} + , loginScreen{nullptr} + , running{true} + , quitOnLastWindowClosed{true} { } @@ -132,8 +132,7 @@ void Nexus::start() minimizeAction = windowMenu->addAction(QString()); minimizeAction->setShortcut(Qt::CTRL + Qt::Key_M); - connect(minimizeAction, &QAction::triggered, [this]() - { + connect(minimizeAction, &QAction::triggered, [this]() { minimizeAction->setEnabled(false); QApplication::focusWindow()->showMinimized(); }); @@ -172,7 +171,8 @@ void Nexus::showLogin() profile = nullptr; loginScreen->reset(); - loginScreen->move(QApplication::desktop()->screen()->rect().center() - loginScreen->rect().center()); + loginScreen->move(QApplication::desktop()->screen()->rect().center() + - loginScreen->rect().center()); loginScreen->show(); quitOnLastWindowClosed = true; } @@ -199,35 +199,36 @@ void Nexus::showMainGUI() // Connections Core* core = profile->getCore(); - connect(core, &Core::connected, widget, &Widget::onConnected); - connect(core, &Core::disconnected, widget, &Widget::onDisconnected); - connect(core, &Core::failedToStart, widget, &Widget::onFailedToStartCore, Qt::BlockingQueuedConnection); - connect(core, &Core::badProxy, widget, &Widget::onBadProxyCore, Qt::BlockingQueuedConnection); - connect(core, &Core::statusSet, widget, &Widget::onStatusSet); - connect(core, &Core::usernameSet, widget, &Widget::setUsername); - connect(core, &Core::statusMessageSet, widget, &Widget::setStatusMessage); - connect(core, &Core::selfAvatarChanged, widget, &Widget::onSelfAvatarLoaded); - connect(core, &Core::friendAdded, widget, &Widget::addFriend); - connect(core, &Core::friendshipChanged, widget, &Widget::onFriendshipChanged); - connect(core, &Core::failedToAddFriend, widget, &Widget::addFriendFailed); - connect(core, &Core::friendUsernameChanged, widget, &Widget::onFriendUsernameChanged); - connect(core, &Core::friendStatusChanged, widget, &Widget::onFriendStatusChanged); + connect(core, &Core::connected, widget, &Widget::onConnected); + connect(core, &Core::disconnected, widget, &Widget::onDisconnected); + connect(core, &Core::failedToStart, widget, &Widget::onFailedToStartCore, + Qt::BlockingQueuedConnection); + connect(core, &Core::badProxy, widget, &Widget::onBadProxyCore, Qt::BlockingQueuedConnection); + connect(core, &Core::statusSet, widget, &Widget::onStatusSet); + connect(core, &Core::usernameSet, widget, &Widget::setUsername); + connect(core, &Core::statusMessageSet, widget, &Widget::setStatusMessage); + connect(core, &Core::selfAvatarChanged, widget, &Widget::onSelfAvatarLoaded); + connect(core, &Core::friendAdded, widget, &Widget::addFriend); + connect(core, &Core::friendshipChanged, widget, &Widget::onFriendshipChanged); + connect(core, &Core::failedToAddFriend, widget, &Widget::addFriendFailed); + connect(core, &Core::friendUsernameChanged, widget, &Widget::onFriendUsernameChanged); + connect(core, &Core::friendStatusChanged, widget, &Widget::onFriendStatusChanged); connect(core, &Core::friendStatusMessageChanged, widget, &Widget::onFriendStatusMessageChanged); - connect(core, &Core::friendRequestReceived, widget, &Widget::onFriendRequestReceived); - connect(core, &Core::friendMessageReceived, widget, &Widget::onFriendMessageReceived); - connect(core, &Core::receiptRecieved, widget, &Widget::onReceiptRecieved); - connect(core, &Core::groupInviteReceived, widget, &Widget::onGroupInviteReceived); - connect(core, &Core::groupMessageReceived, widget, &Widget::onGroupMessageReceived); - connect(core, &Core::groupNamelistChanged, widget, &Widget::onGroupNamelistChanged); - connect(core, &Core::groupTitleChanged, widget, &Widget::onGroupTitleChanged); - connect(core, &Core::groupPeerAudioPlaying, widget, &Widget::onGroupPeerAudioPlaying); - connect(core, &Core::emptyGroupCreated, widget, &Widget::onEmptyGroupCreated); - connect(core, &Core::friendTypingChanged, widget, &Widget::onFriendTypingChanged); - connect(core, &Core::messageSentResult, widget, &Widget::onMessageSendResult); - connect(core, &Core::groupSentResult, widget, &Widget::onGroupSendResult); + connect(core, &Core::friendRequestReceived, widget, &Widget::onFriendRequestReceived); + connect(core, &Core::friendMessageReceived, widget, &Widget::onFriendMessageReceived); + connect(core, &Core::receiptRecieved, widget, &Widget::onReceiptRecieved); + connect(core, &Core::groupInviteReceived, widget, &Widget::onGroupInviteReceived); + connect(core, &Core::groupMessageReceived, widget, &Widget::onGroupMessageReceived); + connect(core, &Core::groupNamelistChanged, widget, &Widget::onGroupNamelistChanged); + connect(core, &Core::groupTitleChanged, widget, &Widget::onGroupTitleChanged); + connect(core, &Core::groupPeerAudioPlaying, widget, &Widget::onGroupPeerAudioPlaying); + connect(core, &Core::emptyGroupCreated, widget, &Widget::onEmptyGroupCreated); + connect(core, &Core::friendTypingChanged, widget, &Widget::onFriendTypingChanged); + connect(core, &Core::messageSentResult, widget, &Widget::onMessageSendResult); + connect(core, &Core::groupSentResult, widget, &Widget::onGroupSendResult); - connect(widget, &Widget::statusSet, core, &Core::setStatus); - connect(widget, &Widget::friendRequested, core, &Core::requestFriendship); + connect(widget, &Widget::statusSet, core, &Core::setStatus); + connect(widget, &Widget::friendRequested, core, &Core::requestFriendship); connect(widget, &Widget::friendRequestAccepted, core, &Core::acceptFriendRequest); profile->startCore(); @@ -314,11 +315,11 @@ Widget* Nexus::getDesktopGUI() QString Nexus::getSupportedImageFilter() { - QString res; - for (auto type : QImageReader::supportedImageFormats()) - res += QString("*.%1 ").arg(QString(type)); + QString res; + for (auto type : QImageReader::supportedImageFormats()) + res += QString("*.%1 ").arg(QString(type)); - return tr("Images (%1)", "filetype filter").arg(res.left(res.size()-1)); + return tr("Images (%1)", "filetype filter").arg(res.left(res.size() - 1)); } /** @@ -362,8 +363,7 @@ void Nexus::onWindowStateChanged(Qt::WindowStates state) { minimizeAction->setEnabled(QApplication::activeWindow() != nullptr); - if (QApplication::activeWindow() != nullptr && sender() == QApplication::activeWindow()) - { + if (QApplication::activeWindow() != nullptr && sender() == QApplication::activeWindow()) { if (state & Qt::WindowFullScreen) minimizeAction->setEnabled(false); @@ -404,8 +404,7 @@ void Nexus::updateWindowsArg(QWindow* closedWindow) else activeWindow = nullptr; - for (int i = 0; i < windowList.size(); ++i) - { + for (int i = 0; i < windowList.size(); ++i) { if (closedWindow == windowList[i]) continue; @@ -432,10 +431,8 @@ void Nexus::updateWindowsStates() bool exists = false; QWindowList windowList = QApplication::topLevelWindows(); - for (QWindow* window : windowList) - { - if (!(window->windowState() & Qt::WindowMinimized)) - { + for (QWindow* window : windowList) { + if (!(window->windowState() & Qt::WindowMinimized)) { exists = true; break; } diff --git a/src/nexus.h b/src/nexus.h index 97437719b..def19f8f9 100644 --- a/src/nexus.h +++ b/src/nexus.h @@ -80,7 +80,7 @@ public slots: void bringAllToFront(); private: - void updateWindowsArg(QWindow *closedWindow); + void updateWindowsArg(QWindow* closedWindow); QSignalMapper* windowMapper; QActionGroup* windowActions = nullptr; @@ -90,7 +90,7 @@ private slots: void onLastWindowClosed(); private: - explicit Nexus(QObject *parent = 0); + explicit Nexus(QObject* parent = 0); ~Nexus(); private: diff --git a/src/persistence/db/rawdatabase.cpp b/src/persistence/db/rawdatabase.cpp index f4fc138cf..018cf0ae3 100644 --- a/src/persistence/db/rawdatabase.cpp +++ b/src/persistence/db/rawdatabase.cpp @@ -42,7 +42,8 @@ * @brief Implements a low level RAII interface to a SQLCipher (SQlite3) database. * * Thread-safe, does all database operations on a worker thread. - * The queries must not contain transaction commands (BEGIN/COMMIT/...) or the behavior is undefined. + * The queries must not contain transaction commands (BEGIN/COMMIT/...) or the behavior is + * undefined. * * @var QMutex RawDatabase::transactionsMutex; * @brief Protects pendingTransactions @@ -94,7 +95,7 @@ RawDatabase::RawDatabase(const QString& path, const QString& password, const QByteArray& salt) : workerThread{new QThread} , path{path} - , currentSalt{salt} // we need the salt later if a new password should be set + , currentSalt{salt} // we need the salt later if a new password should be set , currentHexKey{deriveKey(password, salt)} { workerThread->setObjectName("qTox Database"); @@ -102,8 +103,7 @@ RawDatabase::RawDatabase(const QString& path, const QString& password, const QBy workerThread->start(); // first try with the new salt - if (open(path, currentHexKey)) - { + if (open(path, currentHexKey)) { return; } @@ -112,32 +112,24 @@ RawDatabase::RawDatabase(const QString& path, const QString& password, const QBy // create a backup before trying to upgrade to new salt bool upgrade = true; - if(!QFile::copy(path, path + ".bak")) - { + if (!QFile::copy(path, path + ".bak")) { qDebug() << "Couldn't create the backup of the database, won't upgrade"; upgrade = false; } // fall back to the old salt currentHexKey = deriveKey(password); - if(open(path, currentHexKey)) - { + if (open(path, currentHexKey)) { // upgrade only if backup successful - if(upgrade) - { + if (upgrade) { // still using old salt, upgrade - if(setPassword(password)) - { + if (setPassword(password)) { qDebug() << "Successfully upgraded to dynamic salt"; - } - else - { + } else { qWarning() << "Failed to set password with new salt"; } } - } - else - { + } else { qDebug() << "Failed to open database with old salt"; } } @@ -156,40 +148,36 @@ RawDatabase::~RawDatabase() * @param hexKey Hex representation of the key in string. * @return True if success, false otherwise. */ -bool RawDatabase::open(const QString& path, const QString &hexKey) +bool RawDatabase::open(const QString& path, const QString& hexKey) { - if (QThread::currentThread() != workerThread.get()) - { + if (QThread::currentThread() != workerThread.get()) { bool ret; QMetaObject::invokeMethod(this, "open", Qt::BlockingQueuedConnection, Q_RETURN_ARG(bool, ret), Q_ARG(const QString&, path), Q_ARG(const QString&, hexKey)); return ret; } - if (!QFile::exists(path) && QFile::exists(path+".tmp")) - { - qWarning() << "Restoring database from temporary export file! Did we crash while changing the password?"; - QFile::rename(path+".tmp", path); + if (!QFile::exists(path) && QFile::exists(path + ".tmp")) { + qWarning() << "Restoring database from temporary export file! Did we crash while changing " + "the password?"; + QFile::rename(path + ".tmp", path); } if (sqlite3_open_v2(path.toUtf8().data(), &sqlite, - SQLITE_OPEN_READWRITE | SQLITE_OPEN_CREATE | SQLITE_OPEN_NOMUTEX, nullptr) != SQLITE_OK) - { - qWarning() << "Failed to open database"<{statement}); } @@ -250,10 +238,9 @@ bool RawDatabase::execNow(const RawDatabase::Query &statement) * @param statements List of statements to execute. * @return Whether the transaction was successful. */ -bool RawDatabase::execNow(const QVector &statements) +bool RawDatabase::execNow(const QVector& statements) { - if (!sqlite) - { + if (!sqlite) { qWarning() << "Trying to exec, but the database is not open"; return false; } @@ -283,20 +270,19 @@ bool RawDatabase::execNow(const QVector &statements) * @brief Executes a SQL transaction asynchronously. * @param statement Statement to execute. */ -void RawDatabase::execLater(const QString &statement) +void RawDatabase::execLater(const QString& statement) { execLater(Query{statement}); } -void RawDatabase::execLater(const RawDatabase::Query &statement) +void RawDatabase::execLater(const RawDatabase::Query& statement) { execLater(QVector{statement}); } -void RawDatabase::execLater(const QVector &statements) +void RawDatabase::execLater(const QVector& statements) { - if (!sqlite) - { + if (!sqlite) { qWarning() << "Trying to exec, but the database is not open"; return; } @@ -327,17 +313,15 @@ void RawDatabase::sync() */ bool RawDatabase::setPassword(const QString& password) { - if (!sqlite) - { + if (!sqlite) { qWarning() << "Trying to change the password, but the database is not open"; return false; } - if (QThread::currentThread() != workerThread.get()) - { + if (QThread::currentThread() != workerThread.get()) { bool ret; QMetaObject::invokeMethod(this, "setPassword", Qt::BlockingQueuedConnection, - Q_RETURN_ARG(bool, ret), Q_ARG(const QString&, password)); + Q_RETURN_ARG(bool, ret), Q_ARG(const QString&, password)); return ret; } @@ -345,59 +329,50 @@ bool RawDatabase::setPassword(const QString& password) // so we always process the pending queue before rekeying for consistency process(); - if (QFile::exists(path+".tmp")) - { + if (QFile::exists(path + ".tmp")) { qWarning() << "Found old temporary export file while rekeying, deleting it"; - QFile::remove(path+".tmp"); + QFile::remove(path + ".tmp"); } - if (!password.isEmpty()) - { + if (!password.isEmpty()) { QString newHexKey = deriveKey(password, currentSalt); - if (!currentHexKey.isEmpty()) - { - if (!execNow("PRAGMA rekey = \"x'"+newHexKey+"'\"")) - { + if (!currentHexKey.isEmpty()) { + if (!execNow("PRAGMA rekey = \"x'" + newHexKey + "'\"")) { qWarning() << "Failed to change encryption key"; close(); return false; } - } - else - { + } else { // Need to encrypt the database - if (!execNow("ATTACH DATABASE '"+path+".tmp' AS encrypted KEY \"x'"+newHexKey+"'\";" - "SELECT sqlcipher_export('encrypted');" - "DETACH DATABASE encrypted;")) - { + if (!execNow("ATTACH DATABASE '" + path + ".tmp' AS encrypted KEY \"x'" + newHexKey + + "'\";" + "SELECT sqlcipher_export('encrypted');" + "DETACH DATABASE encrypted;")) { qWarning() << "Failed to export encrypted database"; close(); return false; } // This is racy as hell, but nobody will race with us since we hold the profile lock - // If we crash or die here, the rename should be atomic, so we can recover no matter what + // If we crash or die here, the rename should be atomic, so we can recover no matter + // what close(); QFile::remove(path); - QFile::rename(path+".tmp", path); + QFile::rename(path + ".tmp", path); currentHexKey = newHexKey; - if (!open(path, currentHexKey)) - { + if (!open(path, currentHexKey)) { qWarning() << "Failed to open encrypted database"; return false; } } - } - else - { + } else { if (currentHexKey.isEmpty()) return true; // Need to decrypt the database - if (!execNow("ATTACH DATABASE '"+path+".tmp' AS plaintext KEY '';" - "SELECT sqlcipher_export('plaintext');" - "DETACH DATABASE plaintext;")) - { + if (!execNow("ATTACH DATABASE '" + path + ".tmp' AS plaintext KEY '';" + "SELECT sqlcipher_export('plaintext');" + "DETACH DATABASE plaintext;")) { qWarning() << "Failed to export decrypted database"; close(); return false; @@ -407,10 +382,9 @@ bool RawDatabase::setPassword(const QString& password) // If we crash or die here, the rename should be atomic, so we can recover no matter what close(); QFile::remove(path); - QFile::rename(path+".tmp", path); + QFile::rename(path + ".tmp", path); currentHexKey.clear(); - if (!open(path)) - { + if (!open(path)) { qCritical() << "Failed to open decrypted database"; return false; } @@ -425,19 +399,17 @@ bool RawDatabase::setPassword(const QString& password) * * @note Will process all transactions before renaming */ -bool RawDatabase::rename(const QString &newPath) +bool RawDatabase::rename(const QString& newPath) { - if (!sqlite) - { + if (!sqlite) { qWarning() << "Trying to change the password, but the database is not open"; return false; } - if (QThread::currentThread() != workerThread.get()) - { + if (QThread::currentThread() != workerThread.get()) { bool ret; QMetaObject::invokeMethod(this, "rename", Qt::BlockingQueuedConnection, - Q_RETURN_ARG(bool, ret), Q_ARG(const QString&, newPath)); + Q_RETURN_ARG(bool, ret), Q_ARG(const QString&, newPath)); return ret; } @@ -463,20 +435,19 @@ bool RawDatabase::rename(const QString &newPath) */ bool RawDatabase::remove() { - if (!sqlite) - { + if (!sqlite) { qWarning() << "Trying to remove the database, but it is not open"; return false; } - if (QThread::currentThread() != workerThread.get()) - { + if (QThread::currentThread() != workerThread.get()) { bool ret; - QMetaObject::invokeMethod(this, "remove", Qt::BlockingQueuedConnection, Q_RETURN_ARG(bool, ret)); + QMetaObject::invokeMethod(this, "remove", Qt::BlockingQueuedConnection, + Q_RETURN_ARG(bool, ret)); return ret; } - qDebug() << "Removing database "<< path; + qDebug() << "Removing database " << path; close(); return QFile::remove(path); } @@ -489,7 +460,8 @@ bool RawDatabase::remove() */ struct PassKeyDeleter { - void operator()(Tox_Pass_Key *pass_key) { + void operator()(Tox_Pass_Key* pass_key) + { tox_pass_key_free(pass_key); } }; @@ -500,7 +472,7 @@ struct PassKeyDeleter * @return String representation of key * @deprecated deprecated on 2016-11-06, kept for compatibility, replaced by the salted version */ -QString RawDatabase::deriveKey(const QString &password) +QString RawDatabase::deriveKey(const QString& password) { if (password.isEmpty()) return {}; @@ -509,11 +481,13 @@ QString RawDatabase::deriveKey(const QString &password) static_assert(TOX_PASS_KEY_LENGTH >= 32, "toxcore must provide 256bit or longer keys"); - static const uint8_t expandConstant[TOX_PASS_SALT_LENGTH+1] = "L'ignorance est le pire des maux"; + static const uint8_t expandConstant[TOX_PASS_SALT_LENGTH + 1] = + "L'ignorance est le pire des maux"; std::unique_ptr key(tox_pass_key_new()); tox_pass_key_derive_with_salt(key.get(), reinterpret_cast(passData.data()), static_cast(passData.size()), expandConstant, nullptr); - return QByteArray(reinterpret_cast(key.get()) + 32, 32).toHex();; + return QByteArray(reinterpret_cast(key.get()) + 32, 32).toHex(); + ; } /** @@ -524,13 +498,11 @@ QString RawDatabase::deriveKey(const QString &password) */ QString RawDatabase::deriveKey(const QString& password, const QByteArray& salt) { - if (password.isEmpty()) - { + if (password.isEmpty()) { return {}; } - if (salt.length() != TOX_PASS_SALT_LENGTH) - { + if (salt.length() != TOX_PASS_SALT_LENGTH) { qWarning() << "Salt length doesn't match toxencryptsave expections"; return {}; } @@ -543,7 +515,8 @@ QString RawDatabase::deriveKey(const QString& password, const QByteArray& salt) tox_pass_key_derive_with_salt(key.get(), reinterpret_cast(passData.data()), static_cast(passData.size()), reinterpret_cast(salt.constData()), nullptr); - return QByteArray(reinterpret_cast(key.get()) + 32, 32).toHex();; + return QByteArray(reinterpret_cast(key.get()) + 32, 32).toHex(); + ; } /** @@ -575,28 +548,27 @@ void RawDatabase::process() trans.success->store(false, std::memory_order_release); // Add transaction commands if necessary - if (trans.queries.size() > 1) - { + if (trans.queries.size() > 1) { trans.queries.prepend({"BEGIN;"}); trans.queries.append({"COMMIT;"}); } // Compile queries - for (Query& query : trans.queries) - { + for (Query& query : trans.queries) { assert(query.statements.isEmpty()); // sqlite3_prepare_v2 only compiles one statement at a time in the query, // we need to loop over them all - int curParam=0; + int curParam = 0; const char* compileTail = query.query.data(); do { // Compile the next statement sqlite3_stmt* stmt; int r; if ((r = sqlite3_prepare_v2(sqlite, compileTail, - query.query.size() - static_cast(compileTail - query.query.data()), - &stmt, &compileTail)) != SQLITE_OK) - { + query.query.size() + - static_cast(compileTail - query.query.data()), + &stmt, &compileTail)) + != SQLITE_OK) { qWarning() << "Failed to prepare statement" << anonymizeQuery(query.query) << "with error" << r; goto cleanupStatements; @@ -605,39 +577,34 @@ void RawDatabase::process() // Now we can bind our params to this statement int nParams = sqlite3_bind_parameter_count(stmt); - if (query.blobs.size() < curParam+nParams) - { + if (query.blobs.size() < curParam + nParams) { qWarning() << "Not enough parameters to bind to query " << anonymizeQuery(query.query); goto cleanupStatements; } - for (int i=0; i row; for (int i = 0; i < column_count; ++i) row += extractData(stmt, i); @@ -661,8 +628,7 @@ void RawDatabase::process() qWarning() << "Constraint error executing query" << anonQuery; goto cleanupStatements; default: - qWarning() << "Unknown error" << result - << "executing query" << anonQuery; + qWarning() << "Unknown error" << result << "executing query" << anonQuery; goto cleanupStatements; } } @@ -674,10 +640,9 @@ void RawDatabase::process() if (trans.success != nullptr) trans.success->store(true, std::memory_order_release); - // Free our statements - cleanupStatements: - for (Query& query : trans.queries) - { + // Free our statements + cleanupStatements: + for (Query& query : trans.queries) { for (sqlite3_stmt* stmt : query.statements) sqlite3_finalize(stmt); query.statements.clear(); @@ -711,25 +676,18 @@ QString RawDatabase::anonymizeQuery(const QByteArray& query) * @param col Number of column to extract. * @return Extracted data. */ -QVariant RawDatabase::extractData(sqlite3_stmt *stmt, int col) +QVariant RawDatabase::extractData(sqlite3_stmt* stmt, int col) { int type = sqlite3_column_type(stmt, col); - if (type == SQLITE_INTEGER) - { + if (type == SQLITE_INTEGER) { return sqlite3_column_int64(stmt, col); - } - else if (type == SQLITE_TEXT) - { + } else if (type == SQLITE_TEXT) { const char* str = reinterpret_cast(sqlite3_column_text(stmt, col)); int len = sqlite3_column_bytes(stmt, col); return QString::fromUtf8(str, len); - } - else if (type == SQLITE_NULL) - { + } else if (type == SQLITE_NULL) { return QVariant{}; - } - else - { + } else { const char* data = reinterpret_cast(sqlite3_column_blob(stmt, col)); int len = sqlite3_column_bytes(stmt, col); return QByteArray::fromRawData(data, len); diff --git a/src/persistence/db/rawdatabase.h b/src/persistence/db/rawdatabase.h index 95908bbec..b340039d3 100644 --- a/src/persistence/db/rawdatabase.h +++ b/src/persistence/db/rawdatabase.h @@ -1,16 +1,16 @@ #ifndef RAWDATABASE_H #define RAWDATABASE_H -#include #include -#include -#include -#include -#include #include +#include +#include +#include +#include #include -#include +#include #include +#include struct sqlite3; struct sqlite3_stmt; @@ -23,13 +23,25 @@ public: class Query { public: - Query(QString query, QVector blobs = {}, std::function insertCallback={}) - : query{query.toUtf8()}, blobs{blobs}, insertCallback{insertCallback} {} + Query(QString query, QVector blobs = {}, + std::function insertCallback = {}) + : query{query.toUtf8()} + , blobs{blobs} + , insertCallback{insertCallback} + { + } Query(QString query, std::function insertCallback) - : query{query.toUtf8()}, insertCallback{insertCallback} {} + : query{query.toUtf8()} + , insertCallback{insertCallback} + { + } Query(QString query, std::function&)> rowCallback) - : query{query.toUtf8()}, rowCallback{rowCallback} {} + : query{query.toUtf8()} + , rowCallback{rowCallback} + { + } Query() = default; + private: QByteArray query; QVector blobs; @@ -64,6 +76,7 @@ protected slots: bool open(const QString& path, const QString& hexKey = {}); void close(); void process(); + private: QString anonymizeQuery(const QByteArray& query); diff --git a/src/persistence/history.cpp b/src/persistence/history.cpp index 2f21b11a2..764821d3b 100644 --- a/src/persistence/history.cpp +++ b/src/persistence/history.cpp @@ -20,10 +20,10 @@ #include #include -#include "db/rawdatabase.h" #include "history.h" #include "profile.h" #include "settings.h" +#include "db/rawdatabase.h" /** * @class History @@ -41,31 +41,31 @@ History::History(std::shared_ptr db) : db(db) { - if (!isValid()) - { + if (!isValid()) { qWarning() << "Database not open, init failed"; return; } - db->execLater("CREATE TABLE IF NOT EXISTS peers (id INTEGER PRIMARY KEY, public_key TEXT NOT NULL UNIQUE);" - "CREATE TABLE IF NOT EXISTS aliases (id INTEGER PRIMARY KEY, owner INTEGER," - "display_name BLOB NOT NULL, UNIQUE(owner, display_name));" - "CREATE TABLE IF NOT EXISTS history (id INTEGER PRIMARY KEY, timestamp INTEGER NOT NULL, " - "chat_id INTEGER NOT NULL, sender_alias INTEGER NOT NULL, " - "message BLOB NOT NULL);" - "CREATE TABLE IF NOT EXISTS faux_offline_pending (id INTEGER PRIMARY KEY);"); + db->execLater( + "CREATE TABLE IF NOT EXISTS peers (id INTEGER PRIMARY KEY, public_key TEXT NOT NULL " + "UNIQUE);" + "CREATE TABLE IF NOT EXISTS aliases (id INTEGER PRIMARY KEY, owner INTEGER," + "display_name BLOB NOT NULL, UNIQUE(owner, display_name));" + "CREATE TABLE IF NOT EXISTS history (id INTEGER PRIMARY KEY, timestamp INTEGER NOT NULL, " + "chat_id INTEGER NOT NULL, sender_alias INTEGER NOT NULL, " + "message BLOB NOT NULL);" + "CREATE TABLE IF NOT EXISTS faux_offline_pending (id INTEGER PRIMARY KEY);"); // Cache our current peers - db->execLater(RawDatabase::Query{"SELECT public_key, id FROM peers;", [this](const QVector& row) - { - peers[row[0].toString()] = row[1].toInt(); - }}); + db->execLater(RawDatabase::Query{"SELECT public_key, id FROM peers;", + [this](const QVector& row) { + peers[row[0].toString()] = row[1].toInt(); + }}); } History::~History() { - if (!isValid()) - { + if (!isValid()) { return; } @@ -88,16 +88,15 @@ bool History::isValid() */ void History::eraseHistory() { - if (!isValid()) - { + if (!isValid()) { return; } db->execNow("DELETE FROM faux_offline_pending;" - "DELETE FROM history;" - "DELETE FROM aliases;" - "DELETE FROM peers;" - "VACUUM;"); + "DELETE FROM history;" + "DELETE FROM aliases;" + "DELETE FROM peers;" + "VACUUM;"); } /** @@ -106,36 +105,31 @@ void History::eraseHistory() */ void History::removeFriendHistory(const QString& friendPk) { - if (!isValid()) - { + if (!isValid()) { return; } - if (!peers.contains(friendPk)) - { + if (!peers.contains(friendPk)) { return; } int64_t id = peers[friendPk]; - QString queryText = QString( - "DELETE FROM faux_offline_pending " - "WHERE faux_offline_pending.id IN ( " - " SELECT faux_offline_pending.id FROM faux_offline_pending " - " LEFT JOIN history ON faux_offline_pending.id = history.id " - " WHERE chat_id=%1 " - "); " - "DELETE FROM history WHERE chat_id=%1; " - "DELETE FROM aliases WHERE owner=%1; " - "DELETE FROM peers WHERE id=%1; " - "VACUUM;").arg(id); + QString queryText = QString("DELETE FROM faux_offline_pending " + "WHERE faux_offline_pending.id IN ( " + " SELECT faux_offline_pending.id FROM faux_offline_pending " + " LEFT JOIN history ON faux_offline_pending.id = history.id " + " WHERE chat_id=%1 " + "); " + "DELETE FROM history WHERE chat_id=%1; " + "DELETE FROM aliases WHERE owner=%1; " + "DELETE FROM peers WHERE id=%1; " + "VACUUM;") + .arg(id); - if (db->execNow(queryText)) - { + if (db->execNow(queryText)) { peers.remove(friendPk); - } - else - { + } else { qWarning() << "Failed to remove friend's history"; } } @@ -150,78 +144,73 @@ void History::removeFriendHistory(const QString& friendPk) * @param dispName Name, which should be displayed. * @param insertIdCallback Function, called after query execution. */ -QVector History::generateNewMessageQueries(const QString& friendPk, const QString& message, - const QString& sender, const QDateTime& time, bool isSent, QString dispName, - std::function insertIdCallback) +QVector +History::generateNewMessageQueries(const QString& friendPk, const QString& message, + const QString& sender, const QDateTime& time, bool isSent, + QString dispName, std::function insertIdCallback) { QVector queries; // Get the db id of the peer we're chatting with int64_t peerId; - if (peers.contains(friendPk)) - { + if (peers.contains(friendPk)) { peerId = peers[friendPk]; - } - else - { - if (peers.isEmpty()) - { + } else { + if (peers.isEmpty()) { peerId = 0; - } - else - { + } else { peerId = *std::max_element(peers.begin(), peers.end()) + 1; } peers[friendPk] = peerId; queries += RawDatabase::Query(("INSERT INTO peers (id, public_key) " - "VALUES (%1, '" + friendPk + "');") - .arg(peerId)); + "VALUES (%1, '" + + friendPk + "');") + .arg(peerId)); } // Get the db id of the sender of the message int64_t senderId; - if (peers.contains(sender)) - { + if (peers.contains(sender)) { senderId = peers[sender]; - } - else - { - if (peers.isEmpty()) - { + } else { + if (peers.isEmpty()) { senderId = 0; - } - else - { + } else { senderId = *std::max_element(peers.begin(), peers.end()) + 1; } peers[sender] = senderId; queries += RawDatabase::Query{("INSERT INTO peers (id, public_key) " - "VALUES (%1, '" + sender + "');") - .arg(senderId)}; + "VALUES (%1, '" + + sender + "');") + .arg(senderId)}; } - queries += RawDatabase::Query(QString("INSERT OR IGNORE INTO aliases (owner, display_name) VALUES (%1, ?);") - .arg(senderId), {dispName.toUtf8()}); + queries += RawDatabase::Query( + QString("INSERT OR IGNORE INTO aliases (owner, display_name) VALUES (%1, ?);").arg(senderId), + {dispName.toUtf8()}); - // If the alias already existed, the insert will ignore the conflict and last_insert_rowid() will return garbage, + // If the alias already existed, the insert will ignore the conflict and last_insert_rowid() + // will return garbage, // so we have to check changes() and manually fetch the row ID in this case - queries += RawDatabase::Query(QString("INSERT INTO history (timestamp, chat_id, message, sender_alias) " - "VALUES (%1, %2, ?, (" - " CASE WHEN changes() IS 0 THEN (" - " SELECT id FROM aliases WHERE owner=%3 AND display_name=?)" - " ELSE last_insert_rowid() END" - "));") - .arg(time.toMSecsSinceEpoch()).arg(peerId).arg(senderId), - {message.toUtf8(), dispName.toUtf8()}, insertIdCallback); + queries += + RawDatabase::Query(QString( + "INSERT INTO history (timestamp, chat_id, message, sender_alias) " + "VALUES (%1, %2, ?, (" + " CASE WHEN changes() IS 0 THEN (" + " SELECT id FROM aliases WHERE owner=%3 AND display_name=?)" + " ELSE last_insert_rowid() END" + "));") + .arg(time.toMSecsSinceEpoch()) + .arg(peerId) + .arg(senderId), + {message.toUtf8(), dispName.toUtf8()}, insertIdCallback); - if (!isSent) - { - queries += RawDatabase::Query{ - "INSERT INTO faux_offline_pending (id) VALUES (" - " last_insert_rowid()" - ");"}; + if (!isSent) { + queries += RawDatabase::Query{"INSERT INTO faux_offline_pending (id) VALUES (" + " last_insert_rowid()" + ");"}; } return queries; @@ -237,18 +226,16 @@ QVector History::generateNewMessageQueries(const QString& fr * @param dispName Name, which should be displayed. * @param insertIdCallback Function, called after query execution. */ -void History::addNewMessage(const QString& friendPk, const QString& message, - const QString& sender, const QDateTime& time, - bool isSent, QString dispName, +void History::addNewMessage(const QString& friendPk, const QString& message, const QString& sender, + const QDateTime& time, bool isSent, QString dispName, std::function insertIdCallback) { - if (!isValid()) - { + if (!isValid()) { return; } - db->execLater(generateNewMessageQueries(friendPk, message, sender, time, - isSent, dispName, insertIdCallback)); + db->execLater(generateNewMessageQueries(friendPk, message, sender, time, isSent, dispName, + insertIdCallback)); } /** @@ -258,33 +245,30 @@ void History::addNewMessage(const QString& friendPk, const QString& message, * @param to End of period to fetch. * @return List of messages. */ -QList History::getChatHistory(const QString& friendPk, - const QDateTime& from, +QList History::getChatHistory(const QString& friendPk, const QDateTime& from, const QDateTime& to) { - if (!isValid()) - { + if (!isValid()) { return {}; } QList messages; - auto rowCallback = [&messages](const QVector& row) - { + auto rowCallback = [&messages](const QVector& row) { // dispName and message could have null bytes, QString::fromUtf8 // truncates on null bytes so we strip them messages += {row[0].toLongLong(), - row[1].isNull(), - QDateTime::fromMSecsSinceEpoch(row[2].toLongLong()), - row[3].toString(), - QString::fromUtf8(row[4].toByteArray().replace('\0',"")), - row[5].toString(), - QString::fromUtf8(row[6].toByteArray().replace('\0',""))}; + row[1].isNull(), + QDateTime::fromMSecsSinceEpoch(row[2].toLongLong()), + row[3].toString(), + QString::fromUtf8(row[4].toByteArray().replace('\0', "")), + row[5].toString(), + QString::fromUtf8(row[6].toByteArray().replace('\0', ""))}; }; // Don't forget to update the rowCallback if you change the selected columns! - QString queryText = QString( - "SELECT history.id, faux_offline_pending.id, timestamp, " + QString queryText = + QString("SELECT history.id, faux_offline_pending.id, timestamp, " "chat.public_key, aliases.display_name, sender.public_key, " "message FROM history " "LEFT JOIN faux_offline_pending ON history.id = faux_offline_pending.id " @@ -292,7 +276,9 @@ QList History::getChatHistory(const QString& friendPk, "JOIN aliases ON sender_alias = aliases.id " "JOIN peers sender ON aliases.owner = sender.id " "WHERE timestamp BETWEEN %1 AND %2 AND chat.public_key='%3';") - .arg(from.toMSecsSinceEpoch()).arg(to.toMSecsSinceEpoch()).arg(friendPk); + .arg(from.toMSecsSinceEpoch()) + .arg(to.toMSecsSinceEpoch()) + .arg(friendPk); db->execNow({queryText, rowCallback}); @@ -307,11 +293,9 @@ QList History::getChatHistory(const QString& friendPk, */ void History::markAsSent(qint64 messageId) { - if (!isValid()) - { + if (!isValid()) { return; } - db->execLater(QString("DELETE FROM faux_offline_pending WHERE id=%1;") - .arg(messageId)); + db->execLater(QString("DELETE FROM faux_offline_pending WHERE id=%1;").arg(messageId)); } diff --git a/src/persistence/history.h b/src/persistence/history.h index f8b9ba1c7..58352f6df 100644 --- a/src/persistence/history.h +++ b/src/persistence/history.h @@ -21,8 +21,8 @@ #define HISTORY_H #include -#include #include +#include #include #include @@ -33,14 +33,19 @@ class Profile; class HistoryKeeper; class History -{ +{ public: struct HistMessage { - HistMessage(qint64 id, bool isSent, QDateTime timestamp, QString chat, - QString dispName, QString sender, QString message) - : chat{chat}, sender{sender}, message{message}, dispName{dispName} - , timestamp{timestamp}, id{id}, isSent{isSent} + HistMessage(qint64 id, bool isSent, QDateTime timestamp, QString chat, QString dispName, + QString sender, QString message) + : chat{chat} + , sender{sender} + , message{message} + , dispName{dispName} + , timestamp{timestamp} + , id{id} + , isSent{isSent} { } @@ -62,21 +67,19 @@ public: void eraseHistory(); void removeFriendHistory(const QString& friendPk); - void addNewMessage(const QString& friendPk, const QString& message, - const QString& sender, const QDateTime& time, - bool isSent, QString dispName, - std::function insertIdCallback={}); + void addNewMessage(const QString& friendPk, const QString& message, const QString& sender, + const QDateTime& time, bool isSent, QString dispName, + std::function insertIdCallback = {}); - QList getChatHistory(const QString& friendPk, - const QDateTime& from, + QList getChatHistory(const QString& friendPk, const QDateTime& from, const QDateTime& to); void markAsSent(qint64 messageId); + protected: - QVector generateNewMessageQueries( - const QString& friendPk, const QString& message, - const QString& sender, const QDateTime& time, - bool isSent, QString dispName, - std::function insertIdCallback={}); + QVector + generateNewMessageQueries(const QString& friendPk, const QString& message, + const QString& sender, const QDateTime& time, bool isSent, + QString dispName, std::function insertIdCallback = {}); private: std::shared_ptr db; diff --git a/src/persistence/offlinemsgengine.cpp b/src/persistence/offlinemsgengine.cpp index b30a7003f..d8b1f3db7 100644 --- a/src/persistence/offlinemsgengine.cpp +++ b/src/persistence/offlinemsgengine.cpp @@ -18,11 +18,11 @@ */ #include "offlinemsgengine.h" -#include "src/friend.h" -#include "src/persistence/settings.h" #include "src/core/core.h" +#include "src/friend.h" #include "src/nexus.h" #include "src/persistence/profile.h" +#include "src/persistence/settings.h" #include #include @@ -38,9 +38,9 @@ const int OfflineMsgEngine::offlineTimeout = 20000; QMutex OfflineMsgEngine::globalMutex; -OfflineMsgEngine::OfflineMsgEngine(Friend* frnd) : - mutex(QMutex::Recursive), - f(frnd) +OfflineMsgEngine::OfflineMsgEngine(Friend* frnd) + : mutex(QMutex::Recursive) + , f(frnd) { } @@ -54,12 +54,10 @@ void OfflineMsgEngine::dischargeReceipt(int receipt) Profile* profile = Nexus::getProfile(); auto it = receipts.find(receipt); - if (it != receipts.end()) - { + if (it != receipts.end()) { int mID = it.value(); auto msgIt = undeliveredMsgs.find(mID); - if (msgIt != undeliveredMsgs.end()) - { + if (msgIt != undeliveredMsgs.end()) { if (profile->isHistoryEnabled()) profile->getHistory()->markAsSent(mID); msgIt.value().msg->markAsSent(QDateTime::currentDateTime()); @@ -69,7 +67,8 @@ void OfflineMsgEngine::dischargeReceipt(int receipt) } } -void OfflineMsgEngine::registerReceipt(int receipt, int64_t messageID, ChatMessage::Ptr msg, const QDateTime ×tamp) +void OfflineMsgEngine::registerReceipt(int receipt, int64_t messageID, ChatMessage::Ptr msg, + const QDateTime& timestamp) { QMutexLocker ml(&mutex); @@ -94,24 +93,19 @@ void OfflineMsgEngine::deliverOfflineMsgs() removeAllReceipts(); undeliveredMsgs.clear(); - for (auto iter = msgs.begin(); iter != msgs.end(); ++iter) - { + for (auto iter = msgs.begin(); iter != msgs.end(); ++iter) { auto val = iter.value(); auto key = iter.key(); - if (val.timestamp.msecsTo(QDateTime::currentDateTime()) < offlineTimeout) - { + if (val.timestamp.msecsTo(QDateTime::currentDateTime()) < offlineTimeout) { registerReceipt(val.receipt, key, val.msg, val.timestamp); continue; } QString messageText = val.msg->toString(); int rec; - if (val.msg->isAction()) - { + if (val.msg->isAction()) { rec = Core::getInstance()->sendAction(f->getFriendId(), messageText); - } - else - { + } else { rec = Core::getInstance()->sendMessage(f->getFriendId(), messageText); } diff --git a/src/persistence/offlinemsgengine.h b/src/persistence/offlinemsgengine.h index 6c77441b0..8b2e09236 100644 --- a/src/persistence/offlinemsgengine.h +++ b/src/persistence/offlinemsgengine.h @@ -20,12 +20,12 @@ #ifndef OFFLINEMSGENGINE_H #define OFFLINEMSGENGINE_H -#include -#include -#include +#include "src/chatlog/chatmessage.h" #include #include -#include "src/chatlog/chatmessage.h" +#include +#include +#include class Friend; class QTimer; @@ -34,19 +34,21 @@ class OfflineMsgEngine : public QObject { Q_OBJECT public: - explicit OfflineMsgEngine(Friend *); + explicit OfflineMsgEngine(Friend*); virtual ~OfflineMsgEngine(); static QMutex globalMutex; void dischargeReceipt(int receipt); - void registerReceipt(int receipt, int64_t messageID, ChatMessage::Ptr msg, const QDateTime ×tamp = QDateTime::currentDateTime()); + void registerReceipt(int receipt, int64_t messageID, ChatMessage::Ptr msg, + const QDateTime& timestamp = QDateTime::currentDateTime()); public slots: void deliverOfflineMsgs(); void removeAllReceipts(); private: - struct MsgPtr { + struct MsgPtr + { ChatMessage::Ptr msg; QDateTime timestamp; int receipt; diff --git a/src/persistence/profile.cpp b/src/persistence/profile.cpp index 74ec53a7b..30cffa0a2 100644 --- a/src/persistence/profile.cpp +++ b/src/persistence/profile.cpp @@ -50,8 +50,10 @@ QVector Profile::profiles; Profile::Profile(QString name, const QString& password, bool isNewProfile) - : name{name}, password{password} - , newProfile{isNewProfile}, isRemoved{false} + : name{name} + , password{password} + , newProfile{isNewProfile} + , isRemoved{false} { Settings& s = Settings::getInstance(); s.setCurrentProfile(name); @@ -75,15 +77,14 @@ Profile::Profile(QString name, const QString& password, bool isNewProfile) */ Profile* Profile::loadProfile(QString name, const QString& password) { - if (ProfileLocker::hasLock()) - { - qCritical() << "Tried to load profile "<decrypt(data); - if (data.isEmpty()) - { + if (data.isEmpty()) { qCritical() << "Failed to decrypt the tox save file"; ProfileLocker::unlock(); return nullptr; } - } - else - { - if (!password.isEmpty()) - { + } else { + if (!password.isEmpty()) { qWarning() << "We have a password, but the tox save file is not encrypted"; } } @@ -169,31 +160,27 @@ Profile* Profile::loadProfile(QString name, const QString& password) Profile* Profile::createProfile(QString name, QString password) { std::unique_ptr tmpKey; - if(!password.isEmpty()) - { + if (!password.isEmpty()) { tmpKey = ToxEncrypt::makeToxEncrypt(password); - if (!tmpKey) - { + if (!tmpKey) { qCritical() << "Failed to derive key for the tox save"; return nullptr; } } - if (ProfileLocker::hasLock()) - { - qCritical() << "Tried to create profile "<isReady()) - { + if (!isRemoved && core->isReady()) { saveToxSave(); } @@ -216,8 +202,7 @@ Profile::~Profile() qApp->processEvents(); delete coreThread; - if (!isRemoved) - { + if (!isRemoved) { Settings::getInstance().savePersonal(this); Settings::getInstance().sync(); ProfileLocker::assertLock(); @@ -236,11 +221,10 @@ QVector Profile::getFilesByExt(QString extension) QDir dir(Settings::getInstance().getSettingsDirPath()); QVector out; dir.setFilter(QDir::Files | QDir::NoDotAndDotDot); - dir.setNameFilters(QStringList("*."+extension)); + dir.setNameFilters(QStringList("*." + extension)); QFileInfoList list = dir.entryInfoList(); out.reserve(list.size()); - for (QFileInfo file : list) - { + for (QFileInfo file : list) { out += file.completeBaseName(); } @@ -255,10 +239,8 @@ void Profile::scanProfiles() { profiles.clear(); QVector toxfiles = getFilesByExt("tox"), inifiles = getFilesByExt("ini"); - for (QString toxfile : toxfiles) - { - if (!inifiles.contains(toxfile)) - { + for (QString toxfile : toxfiles) { + if (!inifiles.contains(toxfile)) { Settings::getInstance().createPersonal(toxfile); } @@ -306,49 +288,40 @@ QByteArray Profile::loadToxSave() QString path = Settings::getInstance().getSettingsDirPath() + name + ".tox"; QFile saveFile(path); qint64 fileSize; - qDebug() << "Loading tox save "<decrypt(data); - if (data.isEmpty()) - { + if (data.isEmpty()) { qCritical() << "Failed to decrypt the tox save file"; data.clear(); goto fail; } - } - else - { - if (!password.isEmpty()) - { + } else { + if (!password.isEmpty()) { qWarning() << "We have a password, but the tox save file is not encrypted"; } } @@ -382,19 +355,16 @@ void Profile::saveToxSave(QByteArray data) assert(ProfileLocker::getCurLockName() == name); QString path = Settings::getInstance().getSettingsDirPath() + name + ".tox"; - qDebug() << "Saving tox save to "<encrypt(data); - if (data.isEmpty()) - { + if (data.isEmpty()) { qCritical() << "Failed to encrypt, can't save!"; saveFile.cancelWriting(); return; @@ -404,22 +374,21 @@ void Profile::saveToxSave(QByteArray data) saveFile.write(data); // check if everything got written - if (saveFile.flush()) - { + if (saveFile.flush()) { saveFile.commit(); newProfile = false; - } - else - { + } else { saveFile.cancelWriting(); qCritical() << "Failed to write, can't save!"; } } /** - * @brief Gets the path of the avatar file cached by this profile and corresponding to this owner ID. + * @brief Gets the path of the avatar file cached by this profile and corresponding to this owner + * ID. * @param ownerId Path to avatar of friend with this ID will returned. - * @param forceUnencrypted If true, return the path to the plaintext file even if this is an encrypted profile. + * @param forceUnencrypted If true, return the path to the plaintext file even if this is an + * encrypted profile. * @return Path to the avatar. */ QString Profile::avatarPath(const QString& ownerId, bool forceUnencrypted) @@ -430,13 +399,16 @@ QString Profile::avatarPath(const QString& ownerId, bool forceUnencrypted) QByteArray idData = ownerId.toUtf8(); QByteArray pubkeyData = core->getSelfId().getPublicKey().getKey(); constexpr int hashSize = TOX_PUBLIC_KEY_SIZE; - static_assert(hashSize >= crypto_generichash_BYTES_MIN - && hashSize <= crypto_generichash_BYTES_MAX, "Hash size not supported by libsodium"); + static_assert(hashSize >= crypto_generichash_BYTES_MIN && hashSize <= crypto_generichash_BYTES_MAX, + "Hash size not supported by libsodium"); static_assert(hashSize >= crypto_generichash_KEYBYTES_MIN - && hashSize <= crypto_generichash_KEYBYTES_MAX, "Key size not supported by libsodium"); + && hashSize <= crypto_generichash_KEYBYTES_MAX, + "Key size not supported by libsodium"); QByteArray hash(hashSize, 0); - crypto_generichash((uint8_t*)hash.data(), hashSize, (uint8_t*)idData.data(), idData.size(), (uint8_t*)pubkeyData.data(), pubkeyData.size()); - return Settings::getInstance().getSettingsDirPath() + "avatars/" + hash.toHex().toUpper() + ".png"; + crypto_generichash((uint8_t*)hash.data(), hashSize, (uint8_t*)idData.data(), idData.size(), + (uint8_t*)pubkeyData.data(), pubkeyData.size()); + return Settings::getInstance().getSettingsDirPath() + "avatars/" + hash.toHex().toUpper() + + ".png"; } /** @@ -467,7 +439,7 @@ QPixmap Profile::loadAvatar(const QString& ownerId) */ QByteArray Profile::loadAvatarData(const QString& ownerId) { - return loadAvatarData(ownerId, password); + return loadAvatarData(ownerId, password); } /** @@ -482,21 +454,18 @@ QByteArray Profile::loadAvatarData(const QString& ownerId, const QString& passwo bool encrypted = !password.isEmpty(); // If the encrypted avatar isn't found, try loading the unencrypted one for the same ID - if (!password.isEmpty() && !QFile::exists(path)) - { + if (!password.isEmpty() && !QFile::exists(path)) { encrypted = false; path = avatarPath(ownerId, true); } QFile file(path); - if (!file.open(QIODevice::ReadOnly)) - { + if (!file.open(QIODevice::ReadOnly)) { return {}; } QByteArray pic = file.readAll(); - if (encrypted && !pic.isEmpty()) - { + if (encrypted && !pic.isEmpty()) { // TODO: check if we can use passkey-decrypt(pic) here pic = ToxEncrypt::decryptPass(password, pic); } @@ -506,29 +475,27 @@ QByteArray Profile::loadAvatarData(const QString& ownerId, const QString& passwo void Profile::loadDatabase(const ToxId& id) { - if(isRemoved) - { + if (isRemoved) { qDebug() << "Can't load database of removed profile"; return; } QByteArray salt = id.getPublicKey().getKey(); - if(salt.size() != TOX_PASS_SALT_LENGTH) - { + if (salt.size() != TOX_PASS_SALT_LENGTH) { qWarning() << "Couldn't compute salt from public key" << name; - GUI::showError(QObject::tr("Error"), QObject::tr("qTox couldn't open your chat logs, they will be disabled.")); + GUI::showError(QObject::tr("Error"), + QObject::tr("qTox couldn't open your chat logs, they will be disabled.")); } - // At this point it's too early to load the personal settings (Nexus will do it), so we always load + // At this point it's too early to load the personal settings (Nexus will do it), so we always + // load // the history, and if it fails we can't change the setting now, but we keep a nullptr database = std::make_shared(getDbPath(name), password, salt); - if (database && database->isOpen()) - { + if (database && database->isOpen()) { history.reset(new History(database)); - } - else - { + } else { qWarning() << "Failed to open database for profile" << name; - GUI::showError(QObject::tr("Error"), QObject::tr("qTox couldn't open your chat logs, they will be disabled.")); + GUI::showError(QObject::tr("Error"), + QObject::tr("qTox couldn't open your chat logs, they will be disabled.")); } } @@ -539,22 +506,17 @@ void Profile::loadDatabase(const ToxId& id) */ void Profile::saveAvatar(QByteArray pic, const QString& ownerId) { - if (!password.isEmpty() && !pic.isEmpty()) - { + if (!password.isEmpty() && !pic.isEmpty()) { pic = passkey->encrypt(pic); } QString path = avatarPath(ownerId); QDir(Settings::getInstance().getSettingsDirPath()).mkdir("avatars"); - if (pic.isEmpty()) - { + if (pic.isEmpty()) { QFile::remove(path); - } - else - { + } else { QSaveFile file(path); - if (!file.open(QIODevice::WriteOnly)) - { + if (!file.open(QIODevice::WriteOnly)) { qWarning() << "Tox avatar " << path << " couldn't be saved"; return; } @@ -585,7 +547,8 @@ void Profile::removeAvatar() } /** - * @brief Checks that the history is enabled in the settings, and loaded successfully for this profile. + * @brief Checks that the history is enabled in the settings, and loaded successfully for this + * profile. * @return True if enabled, false otherwise. */ bool Profile::isHistoryEnabled() @@ -616,7 +579,7 @@ void Profile::removeAvatar(const QString& ownerId) bool Profile::exists(QString name) { QString path = Settings::getInstance().getSettingsDirPath() + name; - return QFile::exists(path+".tox"); + return QFile::exists(path + ".tox"); } /** @@ -639,9 +602,8 @@ bool Profile::isEncrypted(QString name) uint8_t data[TOX_PASS_ENCRYPTION_EXTRA_LENGTH] = {0}; QString path = Settings::getInstance().getSettingsDirPath() + name + ".tox"; QFile saveFile(path); - if (!saveFile.open(QIODevice::ReadOnly)) - { - qWarning() << "Couldn't open tox save "< Profile::remove() { - if (isRemoved) - { + if (isRemoved) { qWarning() << "Profile " << name << " is already removed!"; return {}; } isRemoved = true; qDebug() << "Removing profile" << name; - for (int i=0; i Profile::remove() QString path = Settings::getInstance().getSettingsDirPath() + name; ProfileLocker::unlock(); - QFile profileMain {path + ".tox"}; - QFile profileConfig {path + ".ini"}; + QFile profileMain{path + ".tox"}; + QFile profileConfig{path + ".ini"}; QVector ret; - if (!profileMain.remove() && profileMain.exists()) - { + if (!profileMain.remove() && profileMain.exists()) { ret.push_back(profileMain.fileName()); qWarning() << "Could not remove file " << profileMain.fileName(); } - if (!profileConfig.remove() && profileConfig.exists()) - { + if (!profileConfig.remove() && profileConfig.exists()) { ret.push_back(profileConfig.fileName()); qWarning() << "Could not remove file " << profileConfig.fileName(); } QString dbPath = getDbPath(name); - if (database && database->isOpen() && !database->remove() && QFile::exists(dbPath)) - { + if (database && database->isOpen() && !database->remove() && QFile::exists(dbPath)) { ret.push_back(dbPath); qWarning() << "Could not remove file " << dbPath; } @@ -717,23 +673,20 @@ bool Profile::rename(QString newName) QString path = Settings::getInstance().getSettingsDirPath() + name, newPath = Settings::getInstance().getSettingsDirPath() + newName; - if (!ProfileLocker::lock(newName)) - { + if (!ProfileLocker::lock(newName)) { return false; } QFile::rename(path + ".tox", newPath + ".tox"); QFile::rename(path + ".ini", newPath + ".ini"); - if (database) - { + if (database) { database->rename(newName); } bool resetAutorun = Settings::getInstance().getAutorun(); Settings::getInstance().setAutorun(false); Settings::getInstance().setCurrentProfile(newName); - if (resetAutorun) - { + if (resetAutorun) { Settings::getInstance().setAutorun(true); // fixes -p flag in autostart command line } @@ -747,8 +700,7 @@ bool Profile::rename(QString newName) */ bool Profile::checkPassword() { - if (isRemoved) - { + if (isRemoved) { return false; } @@ -771,8 +723,7 @@ const ToxEncrypt& Profile::getPasskey() const void Profile::restartCore() { GUI::setEnabled(false); // Core::reset re-enables it - if (!isRemoved && core->isReady()) - { + if (!isRemoved && core->isReady()) { saveToxSave(); } @@ -790,8 +741,7 @@ void Profile::setPassword(const QString& newPassword) std::unique_ptr oldpasskey = std::move(passkey); password = newPassword; passkey = ToxEncrypt::makeToxEncrypt(password); - if(!passkey) - { + if (!passkey) { qCritical() << "Failed to derive key from password, the profile won't use the new password"; password = oldPassword; passkey = std::move(oldpasskey); @@ -800,8 +750,7 @@ void Profile::setPassword(const QString& newPassword) saveToxSave(); // TODO: ensure the database and the tox save file use the same password - if (database) - { + if (database) { database->setPassword(newPassword); } @@ -810,8 +759,7 @@ void Profile::setPassword(const QString& newPassword) QVector friendList = core->getFriendList(); QVectorIterator i(friendList); - while (i.hasNext()) - { + while (i.hasNext()) { QString friendPublicKey = core->getFriendPublicKey(i.next()).toString(); saveAvatar(loadAvatarData(friendPublicKey, oldPassword), friendPublicKey); } diff --git a/src/persistence/profile.h b/src/persistence/profile.h index 5dc1bba1b..095df4247 100644 --- a/src/persistence/profile.h +++ b/src/persistence/profile.h @@ -21,17 +21,17 @@ #ifndef PROFILE_H #define PROFILE_H -#include "src/core/toxid.h" #include "src/core/toxencrypt.h" +#include "src/core/toxid.h" #include "src/persistence/history.h" -#include #include #include #include #include #include +#include class Core; class QThread; @@ -86,6 +86,7 @@ public: private slots: void loadDatabase(const ToxId& id); + private: Profile(QString name, const QString& password, bool newProfile); static QVector getFilesByExt(QString extension); diff --git a/src/persistence/profilelocker.cpp b/src/persistence/profilelocker.cpp index 9cc2c1ba0..859e64797 100644 --- a/src/persistence/profilelocker.cpp +++ b/src/persistence/profilelocker.cpp @@ -20,8 +20,8 @@ #include "profilelocker.h" #include "src/persistence/settings.h" -#include #include +#include /** * @class ProfileLocker @@ -38,7 +38,7 @@ QString ProfileLocker::curLockName; QString ProfileLocker::lockPathFromName(const QString& name) { - return Settings::getInstance().getSettingsDirPath()+'/'+name+".lock"; + return Settings::getInstance().getSettingsDirPath() + '/' + name + ".lock"; } /** @@ -71,8 +71,7 @@ bool ProfileLocker::lock(QString profile) QLockFile* newLock = new QLockFile(lockPathFromName(profile)); newLock->setStaleLockTime(0); - if (!newLock->tryLock()) - { + if (!newLock->tryLock()) { delete newLock; return false; } @@ -105,22 +104,17 @@ void ProfileLocker::unlock() */ void ProfileLocker::assertLock() { - if (!lockfile) - { + if (!lockfile) { qCritical() << "assertLock: We don't seem to own any lock!"; deathByBrokenLock(); } - if (!QFile(lockPathFromName(curLockName)).exists()) - { + if (!QFile(lockPathFromName(curLockName)).exists()) { QString tmp = curLockName; unlock(); - if (lock(tmp)) - { + if (lock(tmp)) { qCritical() << "assertLock: Lock file was lost, but could be restored"; - } - else - { + } else { qCritical() << "assertLock: Lock file was lost, and could *NOT* be restored"; deathByBrokenLock(); } diff --git a/src/persistence/profilelocker.h b/src/persistence/profilelocker.h index 0d8242d1b..4c2fd5b2d 100644 --- a/src/persistence/profilelocker.h +++ b/src/persistence/profilelocker.h @@ -27,7 +27,7 @@ class ProfileLocker { private: - ProfileLocker()=delete; + ProfileLocker() = delete; public: static bool isLockable(QString profile); diff --git a/src/persistence/serialize.cpp b/src/persistence/serialize.cpp index 624c083ec..d89fde2f9 100644 --- a/src/persistence/serialize.cpp +++ b/src/persistence/serialize.cpp @@ -30,9 +30,8 @@ QString dataToString(QByteArray data) char num3; int strlen = 0; int num2 = 0; - int i=0; - do - { + int i = 0; + do { num3 = data[i++]; strlen |= (num3 & 0x7f) << num2; num2 += 7; @@ -50,14 +49,10 @@ QString dataToString(QByteArray data) uint64_t dataToUint64(const QByteArray& data) { - return static_cast(data[0]) - | (static_cast(data[1]) << 8) - | (static_cast(data[2]) << 16) - | (static_cast(data[3]) << 24) - | (static_cast(data[4]) << 32) - | (static_cast(data[5]) << 40) - | (static_cast(data[6]) << 48) - | (static_cast(data[7]) << 56); + return static_cast(data[0]) | (static_cast(data[1]) << 8) + | (static_cast(data[2]) << 16) | (static_cast(data[3]) << 24) + | (static_cast(data[4]) << 32) | (static_cast(data[5]) << 40) + | (static_cast(data[6]) << 48) | (static_cast(data[7]) << 56); } int dataToVInt(const QByteArray& data) @@ -65,9 +60,8 @@ int dataToVInt(const QByteArray& data) char num3; int num = 0; int num2 = 0; - int i=0; - do - { + int i = 0; + do { num3 = data[i++]; num |= static_cast(num3 & 0x7f) << num2; num2 += 7; @@ -80,9 +74,8 @@ size_t dataToVUint(const QByteArray& data) char num3; size_t num = 0; int num2 = 0; - int i=0; - do - { + int i = 0; + do { num3 = data[i++]; num |= static_cast(num3 & 0x7f) << num2; num2 += 7; @@ -92,7 +85,7 @@ size_t dataToVUint(const QByteArray& data) unsigned getVUint32Size(QByteArray data) { - unsigned lensize=0; + unsigned lensize = 0; char num3; do { @@ -107,15 +100,14 @@ QByteArray vintToData(int num) { QByteArray data(sizeof(int), 0); // Write the size in a Uint of variable lenght (8-32 bits) - int i=0; - while (num >= 0x80) - { + int i = 0; + while (num >= 0x80) { data[i] = static_cast(num | 0x80); ++i; num = num >> 7; } data[i] = static_cast(num); - data.resize(i+1); + data.resize(i + 1); return data; } @@ -123,14 +115,13 @@ QByteArray vuintToData(size_t num) { QByteArray data(sizeof(size_t), 0); // Write the size in a Uint of variable lenght (8-32 bits) - int i=0; - while (num >= 0x80) - { + int i = 0; + while (num >= 0x80) { data[i] = static_cast(num | 0x80); ++i; num = num >> 7; } data[i] = static_cast(num); - data.resize(i+1); + data.resize(i + 1); return data; } diff --git a/src/persistence/serialize.h b/src/persistence/serialize.h index ddbe5b99f..bb40577b7 100644 --- a/src/persistence/serialize.h +++ b/src/persistence/serialize.h @@ -21,9 +21,9 @@ #ifndef SERIALIZE_H #define SERIALIZE_H -#include #include #include +#include QString dataToString(QByteArray data); uint64_t dataToUint64(const QByteArray& data); diff --git a/src/persistence/settings.cpp b/src/persistence/settings.cpp index d08d0b9ea..0c682168f 100644 --- a/src/persistence/settings.cpp +++ b/src/persistence/settings.cpp @@ -19,32 +19,32 @@ */ #include "settings.h" -#include "src/persistence/smileypack.h" -#include "src/core/corestructs.h" #include "src/core/core.h" -#include "src/widget/gui.h" -#include "src/widget/style.h" -#include "src/persistence/profilelocker.h" -#include "src/persistence/settingsserializer.h" +#include "src/core/corestructs.h" #include "src/nexus.h" #include "src/persistence/profile.h" +#include "src/persistence/profilelocker.h" +#include "src/persistence/settingsserializer.h" +#include "src/persistence/smileypack.h" +#include "src/widget/gui.h" +#include "src/widget/style.h" #ifdef QTOX_PLATFORM_EXT #include "src/platform/autorun.h" #endif #include "src/ipc.h" -#include #include +#include +#include #include #include -#include -#include +#include #include -#include -#include #include -#include #include +#include +#include +#include /** * @var QHash Settings::widgetSettings @@ -62,9 +62,11 @@ Settings* Settings::settings{nullptr}; QMutex Settings::bigLock{QMutex::Recursive}; QThread* Settings::settingsThread{nullptr}; -Settings::Settings() : - loaded(false), useCustomDhtList{false}, - makeToxPortable{false}, currentProfileId(0) +Settings::Settings() + : loaded(false) + , useCustomDhtList{false} + , makeToxPortable{false} + , currentProfileId(0) { settingsThread = new QThread(); settingsThread->setObjectName("qTox Settings"); @@ -107,19 +109,15 @@ void Settings::loadGlobal() createSettingsDir(); - QString localSettingsPath = qApp->applicationDirPath() + QDir::separator() - + globalSettingsFile; + QString localSettingsPath = qApp->applicationDirPath() + QDir::separator() + globalSettingsFile; - if (QFile(localSettingsPath).exists()) - { + if (QFile(localSettingsPath).exists()) { QSettings ps(localSettingsPath, QSettings::IniFormat); ps.setIniCodec("UTF-8"); ps.beginGroup("Advanced"); - makeToxPortable = ps.value("makeToxPortable", false).toBool(); + makeToxPortable = ps.value("makeToxPortable", false).toBool(); ps.endGroup(); - } - else - { + } else { makeToxPortable = false; } @@ -127,8 +125,7 @@ void Settings::loadGlobal() QString filePath = dir.filePath(globalSettingsFile); // If no settings file exist -- use the default one - if (!QFile(filePath).exists()) - { + if (!QFile(filePath).exists()) { qDebug() << "No settings file found, using defaults"; filePath = ":/conf/" + globalSettingsFile; } @@ -146,13 +143,11 @@ void Settings::loadGlobal() s.beginGroup("DHT Server"); { - if (s.value("useCustomList").toBool()) - { + if (s.value("useCustomList").toBool()) { useCustomDhtList = true; qDebug() << "Using custom bootstrap nodes list"; int serverListSize = s.beginReadArray("dhtServerList"); - for (int i = 0; i < serverListSize; i ++) - { + for (int i = 0; i < serverListSize; i++) { s.setArrayIndex(i); DhtServer server; server.name = s.value("name").toString(); @@ -162,9 +157,7 @@ void Settings::loadGlobal() dhtServerList << server; } s.endArray(); - } - else - { + } else { useCustomDhtList = false; } } @@ -192,8 +185,7 @@ void Settings::loadGlobal() showSystemTray = s.value("showSystemTray", true).toBool(); autostartInTray = s.value("autostartInTray", false).toBool(); closeToTray = s.value("closeToTray", false).toBool(); - if (currentProfile.isEmpty()) - { + if (currentProfile.isEmpty()) { currentProfile = s.value("currentProfile", "").toString(); currentProfileId = makeProfileId(currentProfile); } @@ -203,10 +195,10 @@ void Settings::loadGlobal() busySound = s.value("busySound", false).toBool(); fauxOfflineMessaging = s.value("fauxOfflineMessaging", true).toBool(); autoSaveEnabled = s.value("autoSaveEnabled", false).toBool(); - globalAutoAcceptDir = s.value("globalAutoAcceptDir", QStandardPaths::locate( - QStandardPaths::HomeLocation, - QString(), - QStandardPaths::LocateDirectory)).toString(); + globalAutoAcceptDir = s.value("globalAutoAcceptDir", + QStandardPaths::locate(QStandardPaths::HomeLocation, QString(), + QStandardPaths::LocateDirectory)) + .toString(); stylePreference = static_cast(s.value("stylePreference", 1).toInt()); } s.endGroup(); @@ -304,23 +296,21 @@ void Settings::loadGlobal() s.endGroup(); // Read the embedded DHT bootstrap nodes list if needed - if (dhtServerList.isEmpty()) - { + if (dhtServerList.isEmpty()) { QSettings rcs(":/conf/settings.ini", QSettings::IniFormat); rcs.setIniCodec("UTF-8"); rcs.beginGroup("DHT Server"); - int serverListSize = rcs.beginReadArray("dhtServerList"); - for (int i = 0; i < serverListSize; i ++) - { - rcs.setArrayIndex(i); - DhtServer server; - server.name = rcs.value("name").toString(); - server.userId = rcs.value("userId").toString(); - server.address = rcs.value("address").toString(); - server.port = static_cast(rcs.value("port").toUInt()); - dhtServerList << server; - } - rcs.endArray(); + int serverListSize = rcs.beginReadArray("dhtServerList"); + for (int i = 0; i < serverListSize; i++) { + rcs.setArrayIndex(i); + DhtServer server; + server.name = rcs.value("name").toString(); + server.userId = rcs.value("userId").toString(); + server.address = rcs.value("address").toString(); + server.port = static_cast(rcs.value("port").toUInt()); + dhtServerList << server; + } + rcs.endArray(); rcs.endGroup(); } @@ -330,8 +320,7 @@ void Settings::loadGlobal() void Settings::loadPersonal() { Profile* profile = Nexus::getProfile(); - if (!profile) - { + if (!profile) { qCritical() << "No active profile, couldn't load personal settings"; return; } @@ -350,7 +339,7 @@ void Settings::loadPersonal(Profile* profile) if (QFile(tmp).exists()) // otherwise, filePath remains the global file filePath = tmp; - qDebug()<<"Loading personal settings from"<getPassword()); ps.load(); @@ -367,8 +356,7 @@ void Settings::loadPersonal(Profile* profile) { int size = ps.beginReadArray("Friend"); friendLst.reserve(size); - for (int i = 0; i < size; i ++) - { + for (int i = 0; i < size; i++) { ps.setArrayIndex(i); friendProp fp; fp.addr = ps.value("addr").toString(); @@ -376,10 +364,11 @@ void Settings::loadPersonal(Profile* profile) fp.note = ps.value("note").toString(); fp.autoAcceptDir = ps.value("autoAcceptDir").toString(); - if(fp.autoAcceptDir == "") + if (fp.autoAcceptDir == "") fp.autoAcceptDir = ps.value("autoAccept").toString(); - fp.autoAcceptCall = Settings::AutoAcceptCallFlags(QFlag(ps.value("autoAcceptCall", 0).toInt())); + fp.autoAcceptCall = + Settings::AutoAcceptCallFlags(QFlag(ps.value("autoAcceptCall", 0).toInt())); fp.circleID = ps.value("circle", -1).toInt(); if (getEnableLogging()) @@ -395,8 +384,7 @@ void Settings::loadPersonal(Profile* profile) int size = ps.beginReadArray("Request"); friendRequests.clear(); friendRequests.reserve(size); - for (int i = 0; i < size; i ++) - { + for (int i = 0; i < size; i++) { ps.setArrayIndex(i); Request request; request.address = ps.value("addr").toString(); @@ -436,8 +424,7 @@ void Settings::loadPersonal(Profile* profile) int size = ps.beginReadArray("Circle"); circleLst.clear(); circleLst.reserve(size); - for (int i = 0; i < size; i ++) - { + for (int i = 0; i < size; i++) { ps.setArrayIndex(i); circleProp cp; cp.name = ps.value("name").toString(); @@ -451,7 +438,7 @@ void Settings::loadPersonal(Profile* profile) ps.beginGroup("Toxme"); { toxmeInfo = ps.value("info", "").toString(); - toxmeBio = ps.value("bio", "").toString(); + toxmeBio = ps.value("bio", "").toString(); toxmePriv = ps.value("priv", false).toBool(); toxmePass = ps.value("pass", "").toString(); } @@ -465,7 +452,7 @@ void Settings::resetToDefault() // Remove file with profile settings QDir dir(getSettingsDirPath()); - Profile *profile = Nexus::getProfile(); + Profile* profile = Nexus::getProfile(); QString localPath = dir.filePath(profile->getName() + ".ini"); QFile local(localPath); if (local.exists()) @@ -478,7 +465,7 @@ void Settings::resetToDefault() void Settings::saveGlobal() { if (QThread::currentThread() != settingsThread) - return (void) QMetaObject::invokeMethod(&getInstance(), "saveGlobal"); + return (void)QMetaObject::invokeMethod(&getInstance(), "saveGlobal"); QMutexLocker locker{&bigLock}; if (!loaded) @@ -502,8 +489,7 @@ void Settings::saveGlobal() { s.setValue("useCustomList", useCustomDhtList); s.beginWriteArray("dhtServerList", dhtServerList.size()); - for (int i = 0; i < dhtServerList.size(); i ++) - { + for (int i = 0; i < dhtServerList.size(); i++) { s.setArrayIndex(i); s.setValue("name", dhtServerList[i].name); s.setValue("userId", dhtServerList[i].userId); @@ -516,9 +502,9 @@ void Settings::saveGlobal() s.beginGroup("General"); { - s.setValue("translation",translation); + s.setValue("translation", translation); s.setValue("showSystemTray", showSystemTray); - s.setValue("autostartInTray",autostartInTray); + s.setValue("autostartInTray", autostartInTray); s.setValue("closeToTray", closeToTray); s.setValue("currentProfile", currentProfile); s.setValue("autoAwayTime", autoAwayTime); @@ -534,7 +520,7 @@ void Settings::saveGlobal() s.beginGroup("Advanced"); { - s.setValue("makeToxPortable",makeToxPortable); + s.setValue("makeToxPortable", makeToxPortable); s.setValue("enableIPv6", enableIPv6); s.setValue("forceTCP", forceTCP); s.setValue("dbSyncType", static_cast(dbSyncType)); @@ -627,8 +613,7 @@ void Settings::savePersonal() */ void Settings::savePersonal(Profile* profile) { - if (!profile) - { + if (!profile) { qDebug() << "Could not save personal settings because there is no active profile"; return; } @@ -638,8 +623,8 @@ void Settings::savePersonal(Profile* profile) void Settings::savePersonal(QString profileName, const QString& password) { if (QThread::currentThread() != settingsThread) - return (void) QMetaObject::invokeMethod(&getInstance(), "savePersonal", - Q_ARG(QString, profileName), Q_ARG(QString, password)); + return (void)QMetaObject::invokeMethod(&getInstance(), "savePersonal", + Q_ARG(QString, profileName), Q_ARG(QString, password)); QMutexLocker locker{&bigLock}; if (!loaded) @@ -654,8 +639,7 @@ void Settings::savePersonal(QString profileName, const QString& password) { ps.beginWriteArray("Friend", friendLst.size()); int index = 0; - for (auto& frnd : friendLst) - { + for (auto& frnd : friendLst) { ps.setArrayIndex(index); ps.setValue("addr", frnd.addr); ps.setValue("alias", frnd.alias); @@ -677,8 +661,7 @@ void Settings::savePersonal(QString profileName, const QString& password) { ps.beginWriteArray("Request", friendRequests.size()); int index = 0; - for (auto& request : friendRequests) - { + for (auto& request : friendRequests) { ps.setArrayIndex(index); ps.setValue("addr", request.address); ps.setValue("message", request.message); @@ -708,8 +691,7 @@ void Settings::savePersonal(QString profileName, const QString& password) { ps.beginWriteArray("Circle", circleLst.size()); int index = 0; - for (auto& circle : circleLst) - { + for (auto& circle : circleLst) { ps.setArrayIndex(index); ps.setValue("name", circle.name); ps.setValue("expanded", circle.expanded); @@ -753,18 +735,23 @@ QString Settings::getSettingsDirPath() const { QMutexLocker locker{&bigLock}; if (makeToxPortable) - return qApp->applicationDirPath()+QDir::separator(); + return qApp->applicationDirPath() + QDir::separator(); - // workaround for https://bugreports.qt-project.org/browse/QTBUG-38845 +// workaround for https://bugreports.qt-project.org/browse/QTBUG-38845 #ifdef Q_OS_WIN - return QDir::cleanPath(QStandardPaths::writableLocation(QStandardPaths::HomeLocation) + QDir::separator() - + "AppData" + QDir::separator() + "Roaming" + QDir::separator() + "tox")+QDir::separator(); + return QDir::cleanPath(QStandardPaths::writableLocation(QStandardPaths::HomeLocation) + + QDir::separator() + "AppData" + QDir::separator() + "Roaming" + + QDir::separator() + "tox") + + QDir::separator(); #elif defined(Q_OS_OSX) - return QDir::cleanPath(QStandardPaths::writableLocation(QStandardPaths::HomeLocation) + QDir::separator() - + "Library" + QDir::separator() + "Application Support" + QDir::separator() + "Tox")+QDir::separator(); + return QDir::cleanPath(QStandardPaths::writableLocation(QStandardPaths::HomeLocation) + + QDir::separator() + "Library" + QDir::separator() + + "Application Support" + QDir::separator() + "Tox") + + QDir::separator(); #else return QDir::cleanPath(QStandardPaths::writableLocation(QStandardPaths::ConfigLocation) - + QDir::separator() + "tox")+QDir::separator(); + + QDir::separator() + "tox") + + QDir::separator(); #endif } @@ -776,22 +763,27 @@ QString Settings::getAppDataDirPath() const { QMutexLocker locker{&bigLock}; if (makeToxPortable) - return qApp->applicationDirPath()+QDir::separator(); + return qApp->applicationDirPath() + QDir::separator(); - // workaround for https://bugreports.qt-project.org/browse/QTBUG-38845 +// workaround for https://bugreports.qt-project.org/browse/QTBUG-38845 #ifdef Q_OS_WIN - return QDir::cleanPath(QStandardPaths::writableLocation(QStandardPaths::HomeLocation) + QDir::separator() - + "AppData" + QDir::separator() + "Roaming" + QDir::separator() + "tox")+QDir::separator(); + return QDir::cleanPath(QStandardPaths::writableLocation(QStandardPaths::HomeLocation) + + QDir::separator() + "AppData" + QDir::separator() + "Roaming" + + QDir::separator() + "tox") + + QDir::separator(); #elif defined(Q_OS_OSX) - return QDir::cleanPath(QStandardPaths::writableLocation(QStandardPaths::HomeLocation) + QDir::separator() - + "Library" + QDir::separator() + "Application Support" + QDir::separator() + "Tox")+QDir::separator(); + return QDir::cleanPath(QStandardPaths::writableLocation(QStandardPaths::HomeLocation) + + QDir::separator() + "Library" + QDir::separator() + + "Application Support" + QDir::separator() + "Tox") + + QDir::separator(); #else /* * TODO: Change QStandardPaths::DataLocation to AppDataLocation when upgrate Qt to 5.4+ * For now we need support Qt 5.3, so we use deprecated DataLocation * BTW, it's not a big deal since for linux AppDataLocation and DataLocation are equal */ - return QDir::cleanPath(QStandardPaths::writableLocation(QStandardPaths::DataLocation))+QDir::separator(); + return QDir::cleanPath(QStandardPaths::writableLocation(QStandardPaths::DataLocation)) + + QDir::separator(); #endif } @@ -803,17 +795,22 @@ QString Settings::getAppCacheDirPath() const { QMutexLocker locker{&bigLock}; if (makeToxPortable) - return qApp->applicationDirPath()+QDir::separator(); + return qApp->applicationDirPath() + QDir::separator(); - // workaround for https://bugreports.qt-project.org/browse/QTBUG-38845 +// workaround for https://bugreports.qt-project.org/browse/QTBUG-38845 #ifdef Q_OS_WIN - return QDir::cleanPath(QStandardPaths::writableLocation(QStandardPaths::HomeLocation) + QDir::separator() - + "AppData" + QDir::separator() + "Roaming" + QDir::separator() + "tox")+QDir::separator(); + return QDir::cleanPath(QStandardPaths::writableLocation(QStandardPaths::HomeLocation) + + QDir::separator() + "AppData" + QDir::separator() + "Roaming" + + QDir::separator() + "tox") + + QDir::separator(); #elif defined(Q_OS_OSX) - return QDir::cleanPath(QStandardPaths::writableLocation(QStandardPaths::HomeLocation) + QDir::separator() - + "Library" + QDir::separator() + "Application Support" + QDir::separator() + "Tox")+QDir::separator(); + return QDir::cleanPath(QStandardPaths::writableLocation(QStandardPaths::HomeLocation) + + QDir::separator() + "Library" + QDir::separator() + + "Application Support" + QDir::separator() + "Tox") + + QDir::separator(); #else - return QDir::cleanPath(QStandardPaths::writableLocation(QStandardPaths::CacheLocation))+QDir::separator(); + return QDir::cleanPath(QStandardPaths::writableLocation(QStandardPaths::CacheLocation)) + + QDir::separator(); #endif } @@ -827,8 +824,7 @@ void Settings::setDhtServerList(const QList& newDhtServerList) { QMutexLocker locker{&bigLock}; - if (newDhtServerList != dhtServerList) - { + if (newDhtServerList != dhtServerList) { dhtServerList = newDhtServerList; emit dhtServerListChanged(dhtServerList); } @@ -843,8 +839,7 @@ void Settings::setEnableTestSound(bool newValue) { QMutexLocker locker{&bigLock}; - if (newValue != enableTestSound) - { + if (newValue != enableTestSound) { enableTestSound = newValue; emit enableTestSoundChanged(enableTestSound); } @@ -860,8 +855,7 @@ void Settings::setEnableIPv6(bool newValue) { QMutexLocker locker{&bigLock}; - if (newValue != enableIPv6) - { + if (newValue != enableIPv6) { enableIPv6 = newValue; emit enableIPv6Changed(enableIPv6); } @@ -877,8 +871,7 @@ void Settings::setMakeToxPortable(bool newValue) { QMutexLocker locker{&bigLock}; - if (newValue != makeToxPortable) - { + if (newValue != makeToxPortable) { QFile(getSettingsDirPath() + globalSettingsFile).remove(); makeToxPortable = newValue; saveGlobal(); @@ -905,8 +898,7 @@ void Settings::setAutorun(bool newValue) bool autorun = Platform::getAutorun(); - if (newValue != autorun) - { + if (newValue != autorun) { Platform::setAutorun(newValue); emit autorunChanged(autorun); } @@ -931,8 +923,7 @@ void Settings::setStyle(const QString& newStyle) { QMutexLocker locker{&bigLock}; - if (newStyle != style) - { + if (newStyle != style) { style = newStyle; emit styleChanged(style); } @@ -948,8 +939,7 @@ void Settings::setShowSystemTray(bool newValue) { QMutexLocker locker{&bigLock}; - if (newValue != showSystemTray) - { + if (newValue != showSystemTray) { showSystemTray = newValue; emit showSystemTrayChanged(newValue); } @@ -959,8 +949,7 @@ void Settings::setUseEmoticons(bool newValue) { QMutexLocker locker{&bigLock}; - if (newValue != useEmoticons) - { + if (newValue != useEmoticons) { useEmoticons = newValue; emit useEmoticonsChanged(useEmoticons); } @@ -976,8 +965,7 @@ void Settings::setAutoSaveEnabled(bool newValue) { QMutexLocker locker{&bigLock}; - if (newValue != autoSaveEnabled) - { + if (newValue != autoSaveEnabled) { autoSaveEnabled = newValue; emit autoSaveEnabledChanged(autoSaveEnabled); } @@ -993,8 +981,7 @@ void Settings::setAutostartInTray(bool newValue) { QMutexLocker locker{&bigLock}; - if (newValue != autostartInTray) - { + if (newValue != autostartInTray) { autostartInTray = newValue; emit autostartInTrayChanged(autostartInTray); } @@ -1010,8 +997,7 @@ void Settings::setCloseToTray(bool newValue) { QMutexLocker locker{&bigLock}; - if (newValue != closeToTray) - { + if (newValue != closeToTray) { closeToTray = newValue; emit closeToTrayChanged(newValue); } @@ -1027,8 +1013,7 @@ void Settings::setMinimizeToTray(bool newValue) { QMutexLocker locker{&bigLock}; - if (newValue != minimizeToTray) - { + if (newValue != minimizeToTray) { minimizeToTray = newValue; emit minimizeToTrayChanged(minimizeToTray); } @@ -1044,8 +1029,7 @@ void Settings::setLightTrayIcon(bool newValue) { QMutexLocker locker{&bigLock}; - if (newValue != lightTrayIcon) - { + if (newValue != lightTrayIcon) { lightTrayIcon = newValue; emit lightTrayIconChanged(lightTrayIcon); } @@ -1061,8 +1045,7 @@ void Settings::setStatusChangeNotificationEnabled(bool newValue) { QMutexLocker locker{&bigLock}; - if (newValue != statusChangeNotificationEnabled) - { + if (newValue != statusChangeNotificationEnabled) { statusChangeNotificationEnabled = newValue; emit statusChangeNotificationEnabledChanged(statusChangeNotificationEnabled); } @@ -1078,8 +1061,7 @@ void Settings::setShowInFront(bool newValue) { QMutexLocker locker{&bigLock}; - if (newValue != showInFront) - { + if (newValue != showInFront) { showInFront = newValue; emit showInFrontChanged(showInFront); } @@ -1095,8 +1077,7 @@ void Settings::setNotifySound(bool newValue) { QMutexLocker locker{&bigLock}; - if (newValue != notifySound) - { + if (newValue != notifySound) { notifySound = newValue; emit notifySoundChanged(notifySound); } @@ -1112,8 +1093,7 @@ void Settings::setBusySound(bool newValue) { QMutexLocker locker{&bigLock}; - if (newValue != busySound) - { + if (newValue != busySound) { busySound = newValue; emit busySoundChanged(busySound); } @@ -1129,8 +1109,7 @@ void Settings::setGroupAlwaysNotify(bool newValue) { QMutexLocker locker{&bigLock}; - if (newValue != groupAlwaysNotify) - { + if (newValue != groupAlwaysNotify) { groupAlwaysNotify = newValue; emit groupAlwaysNotifyChanged(groupAlwaysNotify); } @@ -1146,8 +1125,7 @@ void Settings::setTranslation(const QString& newValue) { QMutexLocker locker{&bigLock}; - if (newValue != translation) - { + if (newValue != translation) { translation = newValue; emit translationChanged(translation); } @@ -1180,15 +1158,11 @@ void Settings::setToxmeInfo(const QString& info) { QMutexLocker locker{&bigLock}; - if (info != toxmeInfo) - { - if (info.split("@").size() == 2) - { + if (info != toxmeInfo) { + if (info.split("@").size() == 2) { toxmeInfo = info; emit toxmeInfoChanged(toxmeInfo); - } - else - { + } else { qWarning() << info << "is not a valid toxme string -> value ignored."; } } @@ -1204,8 +1178,7 @@ void Settings::setToxmeBio(const QString& bio) { QMutexLocker locker{&bigLock}; - if (bio != toxmeBio) - { + if (bio != toxmeBio) { toxmeBio = bio; emit toxmeBioChanged(toxmeBio); } @@ -1221,8 +1194,7 @@ void Settings::setToxmePriv(bool priv) { QMutexLocker locker{&bigLock}; - if (priv != toxmePriv) - { + if (priv != toxmePriv) { toxmePriv = priv; emit toxmePrivChanged(toxmePriv); } @@ -1238,8 +1210,7 @@ void Settings::setToxmePass(const QString& pass) { QMutexLocker locker{&bigLock}; - if (pass != toxmePass) - { + if (pass != toxmePass) { toxmePass = pass; // password is not exposed for security reasons @@ -1257,8 +1228,7 @@ void Settings::setForceTCP(bool newValue) { QMutexLocker locker{&bigLock}; - if (newValue != forceTCP) - { + if (newValue != forceTCP) { forceTCP = newValue; emit forceTCPChanged(forceTCP); } @@ -1267,21 +1237,20 @@ void Settings::setForceTCP(bool newValue) QNetworkProxy Settings::getProxy() const { QNetworkProxy proxy; - switch(Settings::getProxyType()) - { - case ProxyType::ptNone: - proxy.setType(QNetworkProxy::NoProxy); - break; - case ProxyType::ptSOCKS5: - proxy.setType(QNetworkProxy::Socks5Proxy); - break; - case ProxyType::ptHTTP: - proxy.setType(QNetworkProxy::HttpProxy); - break; - default: - proxy.setType(QNetworkProxy::NoProxy); - qWarning() << "Invalid Proxy type, setting to NoProxy"; - break; + switch (Settings::getProxyType()) { + case ProxyType::ptNone: + proxy.setType(QNetworkProxy::NoProxy); + break; + case ProxyType::ptSOCKS5: + proxy.setType(QNetworkProxy::Socks5Proxy); + break; + case ProxyType::ptHTTP: + proxy.setType(QNetworkProxy::HttpProxy); + break; + default: + proxy.setType(QNetworkProxy::NoProxy); + qWarning() << "Invalid Proxy type, setting to NoProxy"; + break; } proxy.setHostName(Settings::getProxyAddr()); @@ -1299,8 +1268,7 @@ void Settings::setProxyType(ProxyType newValue) { QMutexLocker locker{&bigLock}; - if (newValue != proxyType) - { + if (newValue != proxyType) { proxyType = newValue; emit proxyTypeChanged(proxyType); } @@ -1316,8 +1284,7 @@ void Settings::setProxyAddr(const QString& newValue) { QMutexLocker locker{&bigLock}; - if (newValue != proxyAddr) - { + if (newValue != proxyAddr) { proxyAddr = newValue; emit proxyAddressChanged(proxyAddr); } @@ -1333,8 +1300,7 @@ void Settings::setProxyPort(quint16 newValue) { QMutexLocker locker{&bigLock}; - if (newValue != proxyPort) - { + if (newValue != proxyPort) { proxyPort = newValue; emit proxyPortChanged(proxyPort); } @@ -1356,8 +1322,7 @@ void Settings::setCurrentProfile(const QString& profile) { QMutexLocker locker{&bigLock}; - if (profile != currentProfile) - { + if (profile != currentProfile) { currentProfile = profile; currentProfileId = makeProfileId(currentProfile); emit currentProfileChanged(currentProfile); @@ -1375,8 +1340,7 @@ void Settings::setEnableLogging(bool newValue) { QMutexLocker locker{&bigLock}; - if (newValue != enableLogging) - { + if (newValue != enableLogging) { enableLogging = newValue; emit enableLoggingChanged(enableLogging); } @@ -1400,8 +1364,7 @@ void Settings::setAutoAwayTime(int newValue) if (newValue < 0) newValue = 10; - if (newValue != autoAwayTime) - { + if (newValue != autoAwayTime) { autoAwayTime = newValue; emit autoAwayTimeChanged(autoAwayTime); } @@ -1423,12 +1386,9 @@ void Settings::setAutoAcceptDir(const ToxPk& id, const QString& dir) QMutexLocker locker{&bigLock}; auto it = friendLst.find(id.getKey()); - if (it != friendLst.end()) - { + if (it != friendLst.end()) { it->autoAcceptDir = dir; - } - else - { + } else { updateFriendAddress(id.toString()); setAutoAcceptDir(id, dir); } @@ -1450,8 +1410,7 @@ void Settings::setAutoAcceptCall(const ToxPk& id, AutoAcceptCallFlags accept) QMutexLocker locker{&bigLock}; auto it = friendLst.find(id.getKey()); - if(it != friendLst.end()) - { + if (it != friendLst.end()) { it->autoAcceptCall = accept; emit autoAcceptCallChanged(id, accept); } @@ -1473,13 +1432,10 @@ void Settings::setContactNote(const ToxPk& id, const QString& note) QMutexLocker locker{&bigLock}; auto it = friendLst.find(id.getKey()); - if (it != friendLst.end()) - { + if (it != friendLst.end()) { qDebug() << note; it->note = note; - } - else - { + } else { updateFriendAddress(id.toString()); setContactNote(id, note); } @@ -1495,8 +1451,7 @@ void Settings::setGlobalAutoAcceptDir(const QString& newValue) { QMutexLocker locker{&bigLock}; - if (newValue != globalAutoAcceptDir) - { + if (newValue != globalAutoAcceptDir) { globalAutoAcceptDir = newValue; emit globalAutoAcceptDirChanged(globalAutoAcceptDir); } @@ -1512,8 +1467,7 @@ void Settings::setChatMessageFont(const QFont& font) { QMutexLocker locker(&bigLock); - if (font != chatMessageFont) - { + if (font != chatMessageFont) { chatMessageFont = font; emit chatMessageFontChanged(chatMessageFont); } @@ -1523,9 +1477,7 @@ void Settings::setWidgetData(const QString& uniqueName, const QByteArray& data) { QMutexLocker locker{&bigLock}; - if (!widgetSettings.contains(uniqueName) || - widgetSettings[uniqueName] != data) - { + if (!widgetSettings.contains(uniqueName) || widgetSettings[uniqueName] != data) { widgetSettings[uniqueName] = data; emit widgetDataChanged(uniqueName); } @@ -1547,8 +1499,7 @@ void Settings::setSmileyPack(const QString& value) { QMutexLocker locker{&bigLock}; - if (value != smileyPack) - { + if (value != smileyPack) { smileyPack = value; emit smileyPackChanged(smileyPack); } @@ -1564,8 +1515,7 @@ void Settings::setEmojiFontPointSize(int value) { QMutexLocker locker{&bigLock}; - if (value != emojiFontPointSize) - { + if (value != emojiFontPointSize) { emojiFontPointSize = value; emit emojiFontPointSizeChanged(emojiFontPointSize); } @@ -1581,8 +1531,7 @@ void Settings::setTimestampFormat(const QString& format) { QMutexLocker locker{&bigLock}; - if (format != timestampFormat) - { + if (format != timestampFormat) { timestampFormat = format; emit timestampFormatChanged(timestampFormat); } @@ -1598,8 +1547,7 @@ void Settings::setDateFormat(const QString& format) { QMutexLocker locker{&bigLock}; - if (format != dateFormat) - { + if (format != dateFormat) { dateFormat = format; emit dateFormatChanged(dateFormat); } @@ -1615,8 +1563,7 @@ void Settings::setStylePreference(StyleType newValue) { QMutexLocker locker{&bigLock}; - if (newValue != stylePreference) - { + if (newValue != stylePreference) { stylePreference = newValue; emit stylePreferenceChanged(stylePreference); } @@ -1632,8 +1579,7 @@ void Settings::setWindowGeometry(const QByteArray& value) { QMutexLocker locker{&bigLock}; - if (value != windowGeometry) - { + if (value != windowGeometry) { windowGeometry = value; emit windowGeometryChanged(windowGeometry); } @@ -1649,8 +1595,7 @@ void Settings::setWindowState(const QByteArray& value) { QMutexLocker locker{&bigLock}; - if (value != windowState) - { + if (value != windowState) { windowState = value; emit windowStateChanged(windowState); } @@ -1666,8 +1611,7 @@ void Settings::setCheckUpdates(bool newValue) { QMutexLocker locker{&bigLock}; - if (newValue != checkUpdates) - { + if (newValue != checkUpdates) { checkUpdates = newValue; emit checkUpdatesChanged(checkUpdates); } @@ -1683,8 +1627,7 @@ void Settings::setShowWindow(bool newValue) { QMutexLocker locker{&bigLock}; - if (newValue != showWindow) - { + if (newValue != showWindow) { showWindow = newValue; emit showWindowChanged(showWindow); } @@ -1700,8 +1643,7 @@ void Settings::setSplitterState(const QByteArray& value) { QMutexLocker locker{&bigLock}; - if(value != splitterState) - { + if (value != splitterState) { splitterState = value; emit splitterStateChanged(splitterState); } @@ -1717,8 +1659,7 @@ void Settings::setDialogGeometry(const QByteArray& value) { QMutexLocker locker{&bigLock}; - if (value != dialogGeometry) - { + if (value != dialogGeometry) { dialogGeometry = value; emit dialogGeometryChanged(dialogGeometry); } @@ -1734,8 +1675,7 @@ void Settings::setDialogSplitterState(const QByteArray& value) { QMutexLocker locker{&bigLock}; - if (value != dialogSplitterState) - { + if (value != dialogSplitterState) { dialogSplitterState = value; emit dialogSplitterStateChanged(dialogSplitterState); } @@ -1751,8 +1691,7 @@ void Settings::setDialogSettingsGeometry(const QByteArray& value) { QMutexLocker locker{&bigLock}; - if (value != dialogSettingsGeometry) - { + if (value != dialogSettingsGeometry) { dialogSettingsGeometry = value; emit dialogSettingsGeometryChanged(dialogSettingsGeometry); } @@ -1768,8 +1707,7 @@ void Settings::setMinimizeOnClose(bool newValue) { QMutexLocker locker{&bigLock}; - if (newValue != minimizeOnClose) - { + if (newValue != minimizeOnClose) { minimizeOnClose = newValue; emit minimizeOnCloseChanged(minimizeOnClose); } @@ -1785,8 +1723,7 @@ void Settings::setTypingNotification(bool enabled) { QMutexLocker locker{&bigLock}; - if (enabled != typingNotification) - { + if (enabled != typingNotification) { typingNotification = enabled; emit typingNotificationChanged(typingNotification); } @@ -1802,8 +1739,7 @@ void Settings::setInDev(const QString& deviceSpecifier) { QMutexLocker locker{&bigLock}; - if (deviceSpecifier != inDev) - { + if (deviceSpecifier != inDev) { inDev = deviceSpecifier; emit inDevChanged(inDev); } @@ -1819,8 +1755,7 @@ void Settings::setAudioInDevEnabled(bool enabled) { QMutexLocker locker(&bigLock); - if (enabled != audioInDevEnabled) - { + if (enabled != audioInDevEnabled) { audioInDevEnabled = enabled; emit audioInDevEnabledChanged(enabled); } @@ -1836,8 +1771,7 @@ void Settings::setAudioInGainDecibel(qreal dB) { QMutexLocker locker{&bigLock}; - if (dB < audioInGainDecibel || dB > audioInGainDecibel) - { + if (dB < audioInGainDecibel || dB > audioInGainDecibel) { audioInGainDecibel = dB; emit audioInGainDecibelChanged(audioInGainDecibel); } @@ -1853,8 +1787,7 @@ void Settings::setVideoDev(const QString& deviceSpecifier) { QMutexLocker locker{&bigLock}; - if(deviceSpecifier != videoDev) - { + if (deviceSpecifier != videoDev) { videoDev = deviceSpecifier; emit videoDevChanged(videoDev); } @@ -1870,8 +1803,7 @@ void Settings::setOutDev(const QString& deviceSpecifier) { QMutexLocker locker{&bigLock}; - if (deviceSpecifier != outDev) - { + if (deviceSpecifier != outDev) { outDev = deviceSpecifier; emit outDevChanged(outDev); } @@ -1887,8 +1819,7 @@ void Settings::setAudioOutDevEnabled(bool enabled) { QMutexLocker locker(&bigLock); - if(enabled != audioOutDevEnabled) - { + if (enabled != audioOutDevEnabled) { audioOutDevEnabled = enabled; emit audioOutDevEnabledChanged(audioOutDevEnabled); } @@ -1904,8 +1835,7 @@ void Settings::setOutVolume(int volume) { QMutexLocker locker{&bigLock}; - if (volume != outVolume) - { + if (volume != outVolume) { outVolume = volume; emit outVolumeChanged(outVolume); } @@ -1913,7 +1843,7 @@ void Settings::setOutVolume(int volume) QRect Settings::getScreenRegion() const { - QMutexLocker locker (&bigLock); + QMutexLocker locker(&bigLock); return screenRegion; } @@ -1921,8 +1851,7 @@ void Settings::setScreenRegion(const QRect& value) { QMutexLocker locker{&bigLock}; - if (value != screenRegion) - { + if (value != screenRegion) { screenRegion = value; emit screenRegionChanged(screenRegion); } @@ -1938,8 +1867,7 @@ void Settings::setScreenGrabbed(bool value) { QMutexLocker locker{&bigLock}; - if (value != screenGrabbed) - { + if (value != screenGrabbed) { screenGrabbed = value; emit screenGrabbedChanged(screenGrabbed); } @@ -1955,8 +1883,7 @@ void Settings::setCamVideoRes(QRect newValue) { QMutexLocker locker{&bigLock}; - if (newValue != camVideoRes) - { + if (newValue != camVideoRes) { camVideoRes = newValue; emit camVideoResChanged(camVideoRes); } @@ -1972,8 +1899,7 @@ void Settings::setCamVideoFPS(unsigned short newValue) { QMutexLocker locker{&bigLock}; - if (newValue != camVideoFPS) - { + if (newValue != camVideoFPS) { camVideoFPS = newValue; emit camVideoFPSChanged(camVideoFPS); } @@ -1997,12 +1923,9 @@ void Settings::updateFriendAddress(const QString& newAddr) // TODO: using ToxId here is a hack QByteArray key = ToxId(newAddr).getPublicKey().getKey(); auto it = friendLst.find(key); - if (it != friendLst.end()) - { + if (it != friendLst.end()) { it->addr = newAddr; - } - else - { + } else { friendProp fp; fp.addr = newAddr; fp.alias = ""; @@ -2026,12 +1949,9 @@ void Settings::setFriendAlias(const ToxPk& id, const QString& alias) { QMutexLocker locker{&bigLock}; auto it = friendLst.find(id.getKey()); - if (it != friendLst.end()) - { + if (it != friendLst.end()) { it->alias = alias; - } - else - { + } else { friendProp fp; fp.addr = id.toString(); fp.alias = alias; @@ -2053,12 +1973,9 @@ int Settings::getFriendCircleID(const ToxPk& id) const void Settings::setFriendCircleID(const ToxPk& id, int circleID) { auto it = friendLst.find(id.getKey()); - if (it != friendLst.end()) - { + if (it != friendLst.end()) { it->circleID = circleID; - } - else - { + } else { friendProp fp; fp.addr = id.toString(); fp.alias = ""; @@ -2081,12 +1998,9 @@ QDate Settings::getFriendActivity(const ToxPk& id) const void Settings::setFriendActivity(const ToxPk& id, const QDate& activity) { auto it = friendLst.find(id.getKey()); - if (it != friendLst.end()) - { + if (it != friendLst.end()) { it->activity = activity; - } - else - { + } else { friendProp fp; fp.addr = id.toString(); fp.alias = ""; @@ -2114,8 +2028,7 @@ void Settings::setFauxOfflineMessaging(bool value) { QMutexLocker locker{&bigLock}; - if (value != fauxOfflineMessaging) - { + if (value != fauxOfflineMessaging) { fauxOfflineMessaging = value; emit fauxOfflineMessagingChanged(fauxOfflineMessaging); } @@ -2131,8 +2044,7 @@ void Settings::setCompactLayout(bool value) { QMutexLocker locker{&bigLock}; - if (value != compactLayout) - { + if (value != compactLayout) { compactLayout = value; emit compactLayoutChanged(value); } @@ -2148,8 +2060,7 @@ void Settings::setSeparateWindow(bool value) { QMutexLocker locker{&bigLock}; - if (value != separateWindow) - { + if (value != separateWindow) { separateWindow = value; emit separateWindowChanged(value); } @@ -2165,8 +2076,7 @@ void Settings::setDontGroupWindows(bool value) { QMutexLocker locker{&bigLock}; - if (value != dontGroupWindows) - { + if (value != dontGroupWindows) { dontGroupWindows = value; emit dontGroupWindowsChanged(dontGroupWindows); } @@ -2182,8 +2092,7 @@ void Settings::setGroupchatPosition(bool value) { QMutexLocker locker{&bigLock}; - if (value != groupchatPosition) - { + if (value != groupchatPosition) { groupchatPosition = value; emit groupchatPositionChanged(value); } @@ -2234,14 +2143,12 @@ bool Settings::addFriendRequest(const QString& friendAddress, const QString& mes { QMutexLocker locker{&bigLock}; - for (auto queued : friendRequests) - { - if (queued.address == friendAddress) - { - queued.message = message; - queued.read = false; - return false; - } + for (auto queued : friendRequests) { + if (queued.address == friendAddress) { + queued.message = message; + queued.read = false; + return false; + } } Request request; @@ -2316,8 +2223,7 @@ void Settings::setThemeColor(int value) { QMutexLocker locker{&bigLock}; - if (value != themeColor) - { + if (value != themeColor) { themeColor = value; emit themeColorChanged(themeColor); } @@ -2333,8 +2239,7 @@ void Settings::setAutoLogin(bool state) { QMutexLocker locker{&bigLock}; - if (state != autoLogin) - { + if (state != autoLogin) { autoLogin = state; emit autoLoginChanged(autoLogin); } @@ -2354,8 +2259,8 @@ void Settings::createPersonal(QString basename) QSettings ps(path, QSettings::IniFormat); ps.setIniCodec("UTF-8"); ps.beginGroup("Friends"); - ps.beginWriteArray("Friend", 0); - ps.endArray(); + ps.beginWriteArray("Friend", 0); + ps.endArray(); ps.endGroup(); ps.beginGroup("Privacy"); @@ -2378,8 +2283,7 @@ void Settings::createSettingsDir() */ void Settings::sync() { - if (QThread::currentThread() != settingsThread) - { + if (QThread::currentThread() != settingsThread) { QMetaObject::invokeMethod(&getInstance(), "sync", Qt::BlockingQueuedConnection); return; } diff --git a/src/persistence/settings.h b/src/persistence/settings.h index 3b1613135..5a47c4367 100644 --- a/src/persistence/settings.h +++ b/src/persistence/settings.h @@ -21,15 +21,15 @@ #ifndef SETTINGS_HPP #define SETTINGS_HPP +#include "src/core/corestructs.h" +#include +#include #include #include +#include +#include #include #include -#include -#include -#include -#include -#include "src/core/corestructs.h" class ToxPk; class Profile; @@ -46,100 +46,88 @@ class Settings : public QObject Q_ENUMS(StyleType) // general - Q_PROPERTY(bool compactLayout READ getCompactLayout WRITE setCompactLayout - NOTIFY compactLayoutChanged FINAL) - Q_PROPERTY(bool autorun READ getAutorun WRITE setAutorun - NOTIFY autorunChanged FINAL) + Q_PROPERTY(bool compactLayout READ getCompactLayout WRITE setCompactLayout NOTIFY compactLayoutChanged FINAL) + Q_PROPERTY(bool autorun READ getAutorun WRITE setAutorun NOTIFY autorunChanged FINAL) // GUI - Q_PROPERTY(bool separateWindow READ getSeparateWindow - WRITE setSeparateWindow NOTIFY separateWindowChanged FINAL) - Q_PROPERTY(QString smileyPack READ getSmileyPack WRITE setSmileyPack - NOTIFY smileyPackChanged FINAL) - Q_PROPERTY(int emojiFontPointSize READ getEmojiFontPointSize - WRITE setEmojiFontPointSize NOTIFY emojiFontPointSizeChanged - FINAL) - Q_PROPERTY(bool minimizeOnClose READ getMinimizeOnClose - WRITE setMinimizeOnClose NOTIFY minimizeOnCloseChanged FINAL) - Q_PROPERTY(QByteArray windowGeometry READ getWindowGeometry - WRITE setWindowGeometry NOTIFY windowGeometryChanged FINAL) - Q_PROPERTY(QByteArray windowState READ getWindowState WRITE setWindowState - NOTIFY windowStateChanged FINAL) - Q_PROPERTY(QByteArray splitterState READ getSplitterState - WRITE setSplitterState NOTIFY splitterStateChanged FINAL) - Q_PROPERTY(QByteArray dialogGeometry READ getDialogGeometry - WRITE setDialogGeometry NOTIFY dialogGeometryChanged FINAL) - Q_PROPERTY(QByteArray dialogSplitterState READ getDialogSplitterState - WRITE setDialogSplitterState NOTIFY dialogSplitterStateChanged - FINAL) - Q_PROPERTY(QByteArray dialogSettingsGeometry READ getDialogSettingsGeometry - WRITE setDialogSettingsGeometry - NOTIFY dialogSettingsGeometryChanged FINAL) - Q_PROPERTY(QString style READ getStyle WRITE setStyle NOTIFY styleChanged - FINAL) - Q_PROPERTY(bool showSystemTray READ getShowSystemTray - WRITE setShowSystemTray NOTIFY showSystemTrayChanged FINAL) + Q_PROPERTY(bool separateWindow READ getSeparateWindow WRITE setSeparateWindow NOTIFY + separateWindowChanged FINAL) + Q_PROPERTY(QString smileyPack READ getSmileyPack WRITE setSmileyPack NOTIFY smileyPackChanged FINAL) + Q_PROPERTY(int emojiFontPointSize READ getEmojiFontPointSize WRITE setEmojiFontPointSize NOTIFY + emojiFontPointSizeChanged FINAL) + Q_PROPERTY(bool minimizeOnClose READ getMinimizeOnClose WRITE setMinimizeOnClose NOTIFY + minimizeOnCloseChanged FINAL) + Q_PROPERTY(QByteArray windowGeometry READ getWindowGeometry WRITE setWindowGeometry NOTIFY + windowGeometryChanged FINAL) + Q_PROPERTY(QByteArray windowState READ getWindowState WRITE setWindowState NOTIFY windowStateChanged FINAL) + Q_PROPERTY(QByteArray splitterState READ getSplitterState WRITE setSplitterState NOTIFY + splitterStateChanged FINAL) + Q_PROPERTY(QByteArray dialogGeometry READ getDialogGeometry WRITE setDialogGeometry NOTIFY + dialogGeometryChanged FINAL) + Q_PROPERTY(QByteArray dialogSplitterState READ getDialogSplitterState WRITE + setDialogSplitterState NOTIFY dialogSplitterStateChanged FINAL) + Q_PROPERTY(QByteArray dialogSettingsGeometry READ getDialogSettingsGeometry WRITE + setDialogSettingsGeometry NOTIFY dialogSettingsGeometryChanged FINAL) + Q_PROPERTY(QString style READ getStyle WRITE setStyle NOTIFY styleChanged FINAL) + Q_PROPERTY(bool showSystemTray READ getShowSystemTray WRITE setShowSystemTray NOTIFY + showSystemTrayChanged FINAL) // ChatView - Q_PROPERTY(bool groupchatPosition READ getGroupchatPosition - WRITE setGroupchatPosition NOTIFY groupchatPositionChanged FINAL) - Q_PROPERTY(QFont chatMessageFont READ getChatMessageFont - WRITE setChatMessageFont NOTIFY chatMessageFontChanged FINAL) - Q_PROPERTY(StyleType stylePreference READ getStylePreference - WRITE setStylePreference NOTIFY stylePreferenceChanged FINAL) - Q_PROPERTY(QString timestampFormat READ getTimestampFormat - WRITE setTimestampFormat NOTIFY timestampFormatChanged FINAL) - Q_PROPERTY(QString dateFormat READ getDateFormat WRITE setDateFormat - NOTIFY dateFormatChanged FINAL) - Q_PROPERTY(bool statusChangeNotificationEnabled - READ getStatusChangeNotificationEnabled - WRITE setStatusChangeNotificationEnabled - NOTIFY statusChangeNotificationEnabledChanged FINAL) + Q_PROPERTY(bool groupchatPosition READ getGroupchatPosition WRITE setGroupchatPosition NOTIFY + groupchatPositionChanged FINAL) + Q_PROPERTY(QFont chatMessageFont READ getChatMessageFont WRITE setChatMessageFont NOTIFY + chatMessageFontChanged FINAL) + Q_PROPERTY(StyleType stylePreference READ getStylePreference WRITE setStylePreference NOTIFY + stylePreferenceChanged FINAL) + Q_PROPERTY(QString timestampFormat READ getTimestampFormat WRITE setTimestampFormat NOTIFY + timestampFormatChanged FINAL) + Q_PROPERTY(QString dateFormat READ getDateFormat WRITE setDateFormat NOTIFY dateFormatChanged FINAL) + Q_PROPERTY(bool statusChangeNotificationEnabled READ getStatusChangeNotificationEnabled WRITE + setStatusChangeNotificationEnabled NOTIFY statusChangeNotificationEnabledChanged FINAL) // Privacy - Q_PROPERTY(bool typingNotification READ getTypingNotification - WRITE setTypingNotification NOTIFY typingNotificationChanged - FINAL) + Q_PROPERTY(bool typingNotification READ getTypingNotification WRITE setTypingNotification NOTIFY + typingNotificationChanged FINAL) // Audio - Q_PROPERTY(QString inDev READ getInDev WRITE setInDev - NOTIFY inDevChanged FINAL) - Q_PROPERTY(bool audioInDevEnabled READ getAudioInDevEnabled - WRITE setAudioInDevEnabled NOTIFY audioInDevEnabledChanged FINAL) - Q_PROPERTY(qreal audioInGainDecibel READ getAudioInGainDecibel - WRITE setAudioInGainDecibel NOTIFY audioInGainDecibelChanged - FINAL) - Q_PROPERTY(QString outDev READ getOutDev WRITE setOutDev - NOTIFY outDevChanged FINAL) - Q_PROPERTY(bool audioOutDevEnabled READ getAudioOutDevEnabled - WRITE setAudioOutDevEnabled NOTIFY audioOutDevEnabledChanged - FINAL) - Q_PROPERTY(int outVolume READ getOutVolume WRITE setOutVolume - NOTIFY outVolumeChanged FINAL) + Q_PROPERTY(QString inDev READ getInDev WRITE setInDev NOTIFY inDevChanged FINAL) + Q_PROPERTY(bool audioInDevEnabled READ getAudioInDevEnabled WRITE setAudioInDevEnabled NOTIFY + audioInDevEnabledChanged FINAL) + Q_PROPERTY(qreal audioInGainDecibel READ getAudioInGainDecibel WRITE setAudioInGainDecibel + NOTIFY audioInGainDecibelChanged FINAL) + Q_PROPERTY(QString outDev READ getOutDev WRITE setOutDev NOTIFY outDevChanged FINAL) + Q_PROPERTY(bool audioOutDevEnabled READ getAudioOutDevEnabled WRITE setAudioOutDevEnabled NOTIFY + audioOutDevEnabledChanged FINAL) + Q_PROPERTY(int outVolume READ getOutVolume WRITE setOutVolume NOTIFY outVolumeChanged FINAL) // Video - Q_PROPERTY(QString videoDev READ getVideoDev WRITE setVideoDev - NOTIFY videoDevChanged FINAL) - Q_PROPERTY(QRect camVideoRes READ getCamVideoRes WRITE setCamVideoRes - NOTIFY camVideoResChanged FINAL) - Q_PROPERTY(QRect screenRegion READ getScreenRegion WRITE setScreenRegion - NOTIFY screenRegionChanged FINAL) - Q_PROPERTY(bool screenGrabbed READ getScreenGrabbed WRITE setScreenGrabbed - NOTIFY screenGrabbedChanged FINAL) - Q_PROPERTY(quint16 camVideoFPS READ getCamVideoFPS - WRITE setCamVideoFPS NOTIFY camVideoFPSChanged FINAL) + Q_PROPERTY(QString videoDev READ getVideoDev WRITE setVideoDev NOTIFY videoDevChanged FINAL) + Q_PROPERTY(QRect camVideoRes READ getCamVideoRes WRITE setCamVideoRes NOTIFY camVideoResChanged FINAL) + Q_PROPERTY(QRect screenRegion READ getScreenRegion WRITE setScreenRegion NOTIFY screenRegionChanged FINAL) + Q_PROPERTY(bool screenGrabbed READ getScreenGrabbed WRITE setScreenGrabbed NOTIFY screenGrabbedChanged FINAL) + Q_PROPERTY(quint16 camVideoFPS READ getCamVideoFPS WRITE setCamVideoFPS NOTIFY camVideoFPSChanged FINAL) public: - enum class ProxyType {ptNone = 0, ptSOCKS5 = 1, ptHTTP = 2}; - enum class StyleType {NONE = 0, WITH_CHARS = 1, WITHOUT_CHARS = 2}; + enum class ProxyType + { + ptNone = 0, + ptSOCKS5 = 1, + ptHTTP = 2 + }; + enum class StyleType + { + NONE = 0, + WITH_CHARS = 1, + WITHOUT_CHARS = 2 + }; enum class AutoAcceptCall - { - None = 0x00, - Audio = 0x01, - Video = 0x02, - AV = Audio | Video - }; - Q_DECLARE_FLAGS(AutoAcceptCallFlags, AutoAcceptCall) + { + None = 0x00, + Audio = 0x01, + Video = 0x02, + AV = Audio | Video + }; + Q_DECLARE_FLAGS(AutoAcceptCallFlags, AutoAcceptCall) public: static Settings& getInstance(); @@ -468,7 +456,7 @@ public: void setFriendCircleID(const ToxPk& id, int circleID); QDate getFriendActivity(const ToxPk& id) const; - void setFriendActivity(const ToxPk& id, const QDate &date); + void setFriendActivity(const ToxPk& id, const QDate& date); void removeFriendSettings(const ToxPk& id); @@ -529,7 +517,7 @@ public: private: Settings(); ~Settings(); - Settings(Settings &settings) = delete; + Settings(Settings& settings) = delete; Settings& operator=(const Settings&) = delete; private slots: diff --git a/src/persistence/settingsserializer.cpp b/src/persistence/settingsserializer.cpp index eaabb388c..2a5619287 100644 --- a/src/persistence/settingsserializer.cpp +++ b/src/persistence/settingsserializer.cpp @@ -23,11 +23,11 @@ #include "src/core/toxencrypt.h" #include "src/persistence/profile.h" -#include -#include #include -#include +#include +#include #include +#include /** * @class SettingsSerializer @@ -58,7 +58,7 @@ enum class RecordTag : uint8_t * @var static const char magic[]; * @brief Little endian ASCII "QTOX" magic */ -const char SettingsSerializer::magic[] = {0x51,0x54,0x4F,0x58}; +const char SettingsSerializer::magic[] = {0x51, 0x54, 0x4F, 0x58}; QDataStream& writeStream(QDataStream& dataStream, const SettingsSerializer::RecordTag& tag) { @@ -80,7 +80,7 @@ QDataStream& writeStream(QDataStream& dataStream, const QString& str) QDataStream& readStream(QDataStream& dataStream, SettingsSerializer::RecordTag& tag) { - return dataStream >> reinterpret_cast(tag) ; + return dataStream >> reinterpret_cast(tag); } @@ -89,8 +89,7 @@ QDataStream& readStream(QDataStream& dataStream, QByteArray& data) char num3; int num = 0; int num2 = 0; - do - { + do { dataStream.readRawData(&num3, 1); num |= (num3 & 0x7f) << num2; num2 += 7; @@ -100,23 +99,23 @@ QDataStream& readStream(QDataStream& dataStream, QByteArray& data) return dataStream; } -SettingsSerializer::SettingsSerializer(QString filePath, const QString &password) - : path{filePath}, password{password}, - group{-1}, array{-1}, arrayIndex{-1} +SettingsSerializer::SettingsSerializer(QString filePath, const QString& password) + : path{filePath} + , password{password} + , group{-1} + , array{-1} + , arrayIndex{-1} { } -void SettingsSerializer::beginGroup(const QString &prefix) +void SettingsSerializer::beginGroup(const QString& prefix) { if (prefix.isEmpty()) endGroup(); int index = groups.indexOf(prefix); - if (index >= 0) - { + if (index >= 0) { group = index; - } - else - { + } else { group = groups.size(); groups.append(prefix); } @@ -127,22 +126,16 @@ void SettingsSerializer::endGroup() group = -1; } -int SettingsSerializer::beginReadArray(const QString &prefix) +int SettingsSerializer::beginReadArray(const QString& prefix) { auto index = std::find_if(std::begin(arrays), std::end(arrays), - [=](const Array& a) - { - return a.name==prefix; - }); + [=](const Array& a) { return a.name == prefix; }); - if (index != std::end(arrays)) - { + if (index != std::end(arrays)) { array = static_cast(index - std::begin(arrays)); arrayIndex = -1; return index->size; - } - else - { + } else { array = arrays.size(); arrays.push_back({group, 0, prefix, {}}); arrayIndex = -1; @@ -150,23 +143,17 @@ int SettingsSerializer::beginReadArray(const QString &prefix) } } -void SettingsSerializer::beginWriteArray(const QString &prefix, int size) +void SettingsSerializer::beginWriteArray(const QString& prefix, int size) { auto index = std::find_if(std::begin(arrays), std::end(arrays), - [=](const Array& a) - { - return a.name==prefix; - }); + [=](const Array& a) { return a.name == prefix; }); - if (index != std::end(arrays)) - { + if (index != std::end(arrays)) { array = static_cast(index - std::begin(arrays)); arrayIndex = -1; if (size > 0) index->size = std::max(index->size, size); - } - else - { + } else { if (size < 0) size = 0; array = arrays.size(); @@ -185,15 +172,12 @@ void SettingsSerializer::setArrayIndex(int i) arrayIndex = i; } -void SettingsSerializer::setValue(const QString &key, const QVariant &value) +void SettingsSerializer::setValue(const QString& key, const QVariant& value) { Value* v = findValue(key); - if (v) - { + if (v) { v->value = value; - } - else - { + } else { Value nv{group, array, arrayIndex, key, value}; if (array >= 0) arrays[array].values.append(values.size()); @@ -201,7 +185,7 @@ void SettingsSerializer::setValue(const QString &key, const QVariant &value) } } -QVariant SettingsSerializer::value(const QString &key, const QVariant &defaultValue) const +QVariant SettingsSerializer::value(const QString& key, const QVariant& defaultValue) const { const Value* v = findValue(key); if (v) @@ -212,23 +196,18 @@ QVariant SettingsSerializer::value(const QString &key, const QVariant &defaultVa const SettingsSerializer::Value* SettingsSerializer::findValue(const QString& key) const { - if (array != -1) - { - for (const Array& a : arrays) - { + if (array != -1) { + for (const Array& a : arrays) { if (a.group != group) continue; - for (int vi : a.values) - { + for (int vi : a.values) { const Value& v = values[vi]; if (v.arrayIndex == arrayIndex && v.key == key) return &v; } } - } - else - { + } else { for (const Value& v : values) if (v.group == group && v.array == -1 && v.key == key) return &v; @@ -274,8 +253,7 @@ void SettingsSerializer::load() void SettingsSerializer::save() { QSaveFile f(path); - if (!f.open(QIODevice::Truncate | QIODevice::WriteOnly)) - { + if (!f.open(QIODevice::Truncate | QIODevice::WriteOnly)) { qWarning() << "Couldn't open file"; return; } @@ -284,18 +262,15 @@ void SettingsSerializer::save() QDataStream stream(&data, QIODevice::ReadWrite | QIODevice::Append); stream.setVersion(QDataStream::Qt_5_0); - for (int g=-1; g(data.data()))) - { - if (password.isEmpty()) - { + if (tox_is_data_encrypted(reinterpret_cast(data.data()))) { + if (password.isEmpty()) { qCritical() << "The settings file is encrypted, but we don't have a password!"; return; } data = ToxEncrypt::decryptPass(password, data); - if (data.isEmpty()) - { + if (data.isEmpty()) { qCritical() << "Failed to decrypt the settings file"; return; } - } - else - { + } else { if (!password.isEmpty()) qWarning() << "We have a password, but the settings file is not encrypted"; } - if (memcmp(data.data(), magic, 4)) - { + if (memcmp(data.data(), magic, 4)) { qWarning() << "Bad magic!"; return; } @@ -390,45 +352,35 @@ void SettingsSerializer::readSerialized() QDataStream stream(&data, QIODevice::ReadOnly); stream.setVersion(QDataStream::Qt_5_0); - while (!stream.atEnd()) - { + while (!stream.atEnd()) { RecordTag tag; readStream(stream, tag); - if (tag == RecordTag::Value) - { + if (tag == RecordTag::Value) { QByteArray key; QByteArray value; readStream(stream, key); readStream(stream, value); setValue(QString::fromUtf8(key), QVariant(QString::fromUtf8(value))); - } - else if (tag == RecordTag::GroupStart) - { + } else if (tag == RecordTag::GroupStart) { QByteArray prefix; readStream(stream, prefix); beginGroup(QString::fromUtf8(prefix)); - } - else if (tag == RecordTag::ArrayStart) - { + } else if (tag == RecordTag::ArrayStart) { QByteArray prefix; readStream(stream, prefix); beginReadArray(QString::fromUtf8(prefix)); QByteArray sizeData; readStream(stream, sizeData); - if (sizeData.isEmpty()) - { + if (sizeData.isEmpty()) { qWarning("The personal save file is corrupted!"); return; } int size = dataToVInt(sizeData); arrays[array].size = qMax(size, arrays[array].size); - } - else if (tag == RecordTag::ArrayValue) - { + } else if (tag == RecordTag::ArrayValue) { QByteArray indexData; readStream(stream, indexData); - if (indexData.isEmpty()) - { + if (indexData.isEmpty()) { qWarning("The personal save file is corrupted!"); return; } @@ -438,9 +390,7 @@ void SettingsSerializer::readSerialized() readStream(stream, key); readStream(stream, value); setValue(QString::fromUtf8(key), QVariant(QString::fromUtf8(value))); - } - else if (tag == RecordTag::ArrayEnd) - { + } else if (tag == RecordTag::ArrayEnd) { endArray(); } } @@ -459,8 +409,7 @@ void SettingsSerializer::readIni() if (!s.group().isEmpty()) beginGroup(s.group()); - for (QString k : s.childKeys()) - { + for (QString k : s.childKeys()) { setValue(k, s.value(k)); } @@ -470,18 +419,14 @@ void SettingsSerializer::readIni() gstack.push_back(g); // Visit the next group, if any - while (!gstack.isEmpty()) - { + while (!gstack.isEmpty()) { QString g = gstack.takeLast(); - if (g.isEmpty()) - { + if (g.isEmpty()) { if (gstack.isEmpty()) break; else s.endGroup(); - } - else - { + } else { s.beginGroup(g); break; } @@ -495,8 +440,7 @@ void SettingsSerializer::readIni() // Find groups that only have 1 key std::unique_ptr groupSizes{new int[groups.size()]}; memset(groupSizes.get(), 0, static_cast(groups.size()) * sizeof(int)); - for (const Value& v : values) - { + for (const Value& v : values) { if (v.group < 0 || v.group > groups.size()) continue; groupSizes[static_cast(v.group)]++; @@ -504,8 +448,7 @@ void SettingsSerializer::readIni() // Find arrays, remove their size key from the values, and add them to `arrays` QVector groupsToKill; - for (int i=values.size()-1; i>=0; i--) - { + for (int i = values.size() - 1; i >= 0; i--) { const Value& v = values[i]; if (v.group < 0 || v.group > groups.size()) continue; @@ -519,20 +462,16 @@ void SettingsSerializer::readIni() Array a; a.size = v.value.toInt(); int slashIndex = groups[static_cast(v.group)].lastIndexOf('/'); - if (slashIndex == -1) - { + if (slashIndex == -1) { a.group = -1; a.name = groups[static_cast(v.group)]; a.size = v.value.toInt(); - } - else - { + } else { a.group = -1; - for (int i=0; i(v.group)].left(slashIndex)) a.group = i; - a.name = groups[static_cast(v.group)].mid(slashIndex+1); - + a.name = groups[static_cast(v.group)].mid(slashIndex + 1); } groupSizes[static_cast(v.group)]--; groupsToKill.append(static_cast(v.group)); @@ -541,17 +480,15 @@ void SettingsSerializer::readIni() } // Associate each array's values with the array - for (int ai=0; ai(a.group)]+'/'; - arrayPrefix += a.name+'/'; + arrayPrefix += groups[static_cast(a.group)] + '/'; + arrayPrefix += a.name + '/'; // Find groups which represent each array index - for (int g=0; g= 0; vi--) - { + for (int vi = values.size() - 1; vi >= 0; vi--) { Value& v = values[vi]; if (v.group != g) continue; @@ -579,11 +515,9 @@ void SettingsSerializer::readIni() } // Clean up spurious array element groups - std::sort(std::begin(groupsToKill), std::end(groupsToKill), - std::greater_equal()); + std::sort(std::begin(groupsToKill), std::end(groupsToKill), std::greater_equal()); - for (int g : groupsToKill) - { + for (int g : groupsToKill) { if (groupSizes[static_cast(g)]) continue; @@ -600,15 +534,13 @@ void SettingsSerializer::readIni() */ void SettingsSerializer::removeGroup(int group) { - assert(group group) a.group--; } - for (Value& v : values) - { + for (Value& v : values) { assert(v.group != group); if (v.group > group) v.group--; diff --git a/src/persistence/settingsserializer.h b/src/persistence/settingsserializer.h index ab9b832f2..ee56486be 100644 --- a/src/persistence/settingsserializer.h +++ b/src/persistence/settingsserializer.h @@ -20,49 +20,62 @@ #ifndef SETTINGSSERIALIZER_H #define SETTINGSSERIALIZER_H -#include -#include -#include #include +#include +#include +#include class SettingsSerializer { public: - SettingsSerializer(QString filePath, const QString &password=QString()); + SettingsSerializer(QString filePath, const QString& password = QString()); static bool isSerializedFormat(QString filePath); void load(); void save(); - void beginGroup(const QString &prefix); + void beginGroup(const QString& prefix); void endGroup(); - int beginReadArray(const QString &prefix); - void beginWriteArray(const QString &prefix, int size = -1); + int beginReadArray(const QString& prefix); + void beginWriteArray(const QString& prefix, int size = -1); void endArray(); void setArrayIndex(int i); - void setValue(const QString &key, const QVariant &value); - QVariant value(const QString &key, const QVariant &defaultValue = QVariant()) const; + void setValue(const QString& key, const QVariant& value); + QVariant value(const QString& key, const QVariant& defaultValue = QVariant()) const; private: enum class RecordTag : uint8_t { - Value=0, - GroupStart=1, - ArrayStart=2, - ArrayValue=3, - ArrayEnd=4, + Value = 0, + GroupStart = 1, + ArrayStart = 2, + ArrayValue = 3, + ArrayEnd = 4, }; friend QDataStream& writeStream(QDataStream& dataStream, const SettingsSerializer::RecordTag& tag); friend QDataStream& readStream(QDataStream& dataStream, SettingsSerializer::RecordTag& tag); struct Value { - Value() : group{-2},array{-2},arrayIndex{-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} {} + : group{group} + , array{array} + , arrayIndex{arrayIndex} + , key{key} + , value{value} + { + } qint64 group; qint64 array; int arrayIndex; @@ -79,8 +92,8 @@ private: }; private: - const Value *findValue(const QString& key) const; - Value *findValue(const QString& key); + const Value* findValue(const QString& key) const; + Value* findValue(const QString& key); void readSerialized(); void readIni(); void removeValue(const QString& key); diff --git a/src/persistence/smileypack.cpp b/src/persistence/smileypack.cpp index 2228272e4..e1406aa54 100644 --- a/src/persistence/smileypack.cpp +++ b/src/persistence/smileypack.cpp @@ -22,9 +22,14 @@ #include "src/widget/style.h" #include +#include +#include #include #include +#include #include +#include +#include #include #include #include @@ -32,11 +37,6 @@ #include #include #include -#include -#include -#include -#include -#include #include #include #include @@ -73,8 +73,8 @@ SmileyPack::SmileyPack() { loadingMutex.lock(); QtConcurrent::run(this, &SmileyPack::load, Settings::getInstance().getSmileyPack()); - connect(&Settings::getInstance(), &Settings::smileyPackChanged, - this, &SmileyPack::onSmileyPackChanged); + connect(&Settings::getInstance(), &Settings::smileyPackChanged, this, + &SmileyPack::onSmileyPackChanged); } /** @@ -93,7 +93,8 @@ QStringList SmileyPack::loadDefaultPaths() // Workaround to fix https://bugreports.qt.io/browse/QTBUG-57522 setlocale(LC_ALL, ""); #endif - QStringList paths = QStringList{":/smileys", "~/.kde4/share/emoticons", "~/.kde/share/emoticons"}; + QStringList paths = + QStringList{":/smileys", "~/.kde4/share/emoticons", "~/.kde/share/emoticons"}; // qTox should find emoticons next to the binary paths.append('.' + QDir::separator() + EMOTICONS_SUB_DIR); @@ -105,21 +106,17 @@ QStringList SmileyPack::loadDefaultPaths() #warning "Qt < 5.4.0 has a trouble with unicode symbols in path on few systems" location = QStandardPaths::DataLocation; #endif - for(auto qtoxPath : QStandardPaths::standardLocations(location)) - { + for (auto qtoxPath : QStandardPaths::standardLocations(location)) { qtoxPath += QDir::separator() + EMOTICONS_SUB_DIR; - if(!paths.contains(qtoxPath)) - { + if (!paths.contains(qtoxPath)) { paths << qtoxPath; } } // system wide emoticons - for(auto genericPath : QStandardPaths::standardLocations(QStandardPaths::GenericDataLocation)) - { + for (auto genericPath : QStandardPaths::standardLocations(QStandardPaths::GenericDataLocation)) { genericPath += QDir::separator() + EMOTICONS_SUB_DIR; - if(!paths.contains(genericPath)) - { + if (!paths.contains(genericPath)) { paths << genericPath; } } @@ -134,33 +131,27 @@ QList> SmileyPack::listSmileyPacks() QList> SmileyPack::listSmileyPacks(const QStringList& paths) { - QList > smileyPacks; + QList> smileyPacks; - for (QString path : paths) - { - if (path.leftRef(1) == "~") - { + for (QString path : paths) { + if (path.leftRef(1) == "~") { path.replace(0, 1, QDir::homePath()); } QDir dir(path); - if (!dir.exists()) - { + if (!dir.exists()) { continue; } - for (const QString& subdirectory : dir.entryList(QDir::Dirs | QDir::NoDotAndDotDot)) - { + for (const QString& subdirectory : dir.entryList(QDir::Dirs | QDir::NoDotAndDotDot)) { dir.cd(subdirectory); QFileInfoList entries = dir.entryInfoList(QStringList() << "emoticons.xml", QDir::Files); // Does it contain a file called emoticons.xml? - if (entries.size() > 0) - { + if (entries.size() > 0) { QString packageName = dir.dirName(); QString absPath = entries[0].absoluteFilePath(); - if (!smileyPacks.contains(QPair(packageName, absPath))) - { + if (!smileyPacks.contains(QPair(packageName, absPath))) { smileyPacks << QPair(packageName, absPath); } } @@ -193,8 +184,7 @@ bool SmileyPack::load(const QString& filename) // open emoticons.xml QFile xmlFile(filename); - if (!xmlFile.open(QIODevice::ReadOnly)) - { + if (!xmlFile.open(QIODevice::ReadOnly)) { loadingMutex.unlock(); return false; // cannot open file } @@ -220,32 +210,26 @@ bool SmileyPack::load(const QString& filename) doc.setContent(xmlFile.readAll()); QDomNodeList emoticonElements = doc.elementsByTagName("emoticon"); - for (int i = 0; i < emoticonElements.size(); ++i) - { + for (int i = 0; i < emoticonElements.size(); ++i) { QString file = emoticonElements.at(i).attributes().namedItem("file").nodeValue(); QDomElement stringElement = emoticonElements.at(i).firstChildElement("string"); QStringList emoticonSet; // { ":)", ":-)" } etc. - while (!stringElement.isNull()) - { - QString emoticon = stringElement.text() - .replace("<","<").replace(">",">"); + while (!stringElement.isNull()) { + QString emoticon = stringElement.text().replace("<", "<").replace(">", ">"); filenameTable.insert(emoticon, file); cacheSmiley(file); // preload all smileys - if (!getCachedSmiley(emoticon).isNull()) - { + if (!getCachedSmiley(emoticon).isNull()) { emoticonSet.push_back(emoticon); } stringElement = stringElement.nextSibling().toElement(); - } - if (emoticonSet.size() > 0) - { + if (emoticonSet.size() > 0) { emoticons.push_back(emoticonSet); } } @@ -264,11 +248,9 @@ QString SmileyPack::smileyfied(QString msg) int index = msg.indexOf(exp); // if a word is key of a smiley, replace it by its corresponding image in Rich Text - while (index >= 0) - { + while (index >= 0) { QString key = exp.cap(); - if (filenameTable.contains(key)) - { + if (filenameTable.contains(key)) { QString imgRichText = getAsRichText(key); msg.replace(index, key.length(), imgRichText); @@ -309,15 +291,13 @@ void SmileyPack::cacheSmiley(const QString& name) QIcon SmileyPack::getCachedSmiley(const QString& key) { // valid key? - if (!filenameTable.contains(key)) - { + if (!filenameTable.contains(key)) { return QPixmap(); } // cache it if needed QString file = filenameTable.value(key); - if (!iconCache.contains(file)) - { + if (!iconCache.contains(file)) { cacheSmiley(file); } diff --git a/src/persistence/smileypack.h b/src/persistence/smileypack.h index b8e093cdd..d8a8e9afa 100644 --- a/src/persistence/smileypack.h +++ b/src/persistence/smileypack.h @@ -21,11 +21,11 @@ #define SMILEYPACK_H #include +#include +#include #include #include #include -#include -#include class SmileyPack : public QObject { diff --git a/src/persistence/toxsave.cpp b/src/persistence/toxsave.cpp index 37d051301..1882693a1 100644 --- a/src/persistence/toxsave.cpp +++ b/src/persistence/toxsave.cpp @@ -18,9 +18,9 @@ */ #include "toxsave.h" -#include "src/widget/gui.h" #include "src/core/core.h" #include "src/persistence/settings.h" +#include "src/widget/gui.h" #include "src/widget/tool/profileimporter.h" #include #include @@ -44,8 +44,7 @@ bool handleToxSave(const QString& path) { Core* core = Core::getInstance(); - while (!core) - { + while (!core) { core = Core::getInstance(); qApp->processEvents(); } diff --git a/src/platform/autorun.h b/src/platform/autorun.h index 816ba56cf..44b999781 100644 --- a/src/platform/autorun.h +++ b/src/platform/autorun.h @@ -23,10 +23,9 @@ #define PLATFORM_AUTORUN_H -namespace Platform -{ - bool setAutorun(bool on); - bool getAutorun(); +namespace Platform { +bool setAutorun(bool on); +bool getAutorun(); } #endif // PLATFORM_AUTORUN_H diff --git a/src/platform/autorun_osx.cpp b/src/platform/autorun_osx.cpp index da29569a5..33c28d453 100644 --- a/src/platform/autorun_osx.cpp +++ b/src/platform/autorun_osx.cpp @@ -19,21 +19,24 @@ #if defined(__APPLE__) && defined(__MACH__) #include "src/platform/autorun.h" -#include +#include #include #include +#include #include -#include -int state ; +int state; bool Platform::setAutorun(bool on) { - QString qtoxPlist = QDir::cleanPath(QStandardPaths::writableLocation(QStandardPaths::HomeLocation) + QDir::separator() + - "Library" + QDir::separator() + "LaunchAgents" + QDir::separator() + "chat.tox.qtox.autorun.plist"); - QString qtoxDir = QDir::cleanPath(QCoreApplication::applicationDirPath() + QDir::separator() + "qtox"); + QString qtoxPlist = + QDir::cleanPath(QStandardPaths::writableLocation(QStandardPaths::HomeLocation) + + QDir::separator() + "Library" + QDir::separator() + "LaunchAgents" + + QDir::separator() + "chat.tox.qtox.autorun.plist"); + QString qtoxDir = + QDir::cleanPath(QCoreApplication::applicationDirPath() + QDir::separator() + "qtox"); QSettings autoRun(qtoxPlist, QSettings::NativeFormat); - autoRun.setValue("Label","chat.tox.qtox.autorun"); + autoRun.setValue("Label", "chat.tox.qtox.autorun"); autoRun.setValue("Program", qtoxDir); state = on; @@ -46,4 +49,4 @@ bool Platform::getAutorun() return state; } -#endif // defined(__APPLE__) && defined(__MACH__) +#endif // defined(__APPLE__) && defined(__MACH__) diff --git a/src/platform/autorun_win.cpp b/src/platform/autorun_win.cpp index 43eee82a6..0278809ef 100644 --- a/src/platform/autorun_win.cpp +++ b/src/platform/autorun_win.cpp @@ -19,10 +19,10 @@ #include #ifdef Q_OS_WIN32 -#include "src/platform/autorun.h" #include "src/persistence/settings.h" -#include +#include "src/platform/autorun.h" #include +#include #ifdef UNICODE /** @@ -31,43 +31,48 @@ * easier to reuse and compatible with both setups. */ using tstring = std::wstring; -static inline tstring toTString(QString s) { return s.toStdWString(); } +static inline tstring toTString(QString s) +{ + return s.toStdWString(); +} #else using tstring = std::string; -static inline tstring toTString(QString s) { return s.toStdString(); } +static inline tstring toTString(QString s) +{ + return s.toStdString(); +} #endif -namespace Platform +namespace Platform { +inline tstring currentCommandLine() { - inline tstring currentCommandLine() - { - return toTString("\"" + QApplication::applicationFilePath().replace('/', '\\') + "\" -p \"" + - Settings::getInstance().getCurrentProfile() + "\""); - } + return toTString("\"" + QApplication::applicationFilePath().replace('/', '\\') + "\" -p \"" + + Settings::getInstance().getCurrentProfile() + "\""); +} - inline tstring currentRegistryKeyName() - { - return toTString("qTox - " + Settings::getInstance().getCurrentProfile()); - } +inline tstring currentRegistryKeyName() +{ + return toTString("qTox - " + Settings::getInstance().getCurrentProfile()); +} } bool Platform::setAutorun(bool on) { HKEY key = 0; if (RegOpenKeyEx(HKEY_CURRENT_USER, TEXT("Software\\Microsoft\\Windows\\CurrentVersion\\Run"), - 0, KEY_ALL_ACCESS, &key) != ERROR_SUCCESS) + 0, KEY_ALL_ACCESS, &key) + != ERROR_SUCCESS) return false; bool result = false; tstring keyName = currentRegistryKeyName(); - if (on) - { + if (on) { tstring path = currentCommandLine(); result = RegSetValueEx(key, keyName.c_str(), 0, REG_SZ, (PBYTE)path.c_str(), - path.length() * sizeof(TCHAR)) == ERROR_SUCCESS; - } - else + path.length() * sizeof(TCHAR)) + == ERROR_SUCCESS; + } else result = RegDeleteValue(key, keyName.c_str()) == ERROR_SUCCESS; RegCloseKey(key); @@ -78,21 +83,23 @@ bool Platform::getAutorun() { HKEY key = 0; if (RegOpenKeyEx(HKEY_CURRENT_USER, TEXT("Software\\Microsoft\\Windows\\CurrentVersion\\Run"), - 0, KEY_ALL_ACCESS, &key) != ERROR_SUCCESS) + 0, KEY_ALL_ACCESS, &key) + != ERROR_SUCCESS) return false; tstring keyName = currentRegistryKeyName(); - TCHAR path[MAX_PATH] = { 0 }; + TCHAR path[MAX_PATH] = {0}; DWORD length = sizeof(path); DWORD type = REG_SZ; bool result = false; - if (RegQueryValueEx(key, keyName.c_str(), 0, &type, (PBYTE)path, &length) == ERROR_SUCCESS && type == REG_SZ) + if (RegQueryValueEx(key, keyName.c_str(), 0, &type, (PBYTE)path, &length) == ERROR_SUCCESS + && type == REG_SZ) result = true; RegCloseKey(key); return result; } -#endif // Q_OS_WIN32 +#endif // Q_OS_WIN32 diff --git a/src/platform/autorun_xdg.cpp b/src/platform/autorun_xdg.cpp index 2980697c9..a3db3ece9 100644 --- a/src/platform/autorun_xdg.cpp +++ b/src/platform/autorun_xdg.cpp @@ -19,43 +19,39 @@ #include #if defined(Q_OS_UNIX) && !defined(__APPLE__) && !defined(__MACH__) -#include "src/platform/autorun.h" #include "src/persistence/settings.h" -#include +#include "src/platform/autorun.h" #include +#include -namespace Platform +namespace Platform { +QString getAutostartDirPath() { - QString getAutostartDirPath() - { - QProcessEnvironment env = QProcessEnvironment::systemEnvironment(); - QString config = env.value("XDG_CONFIG_HOME"); - if (config.isEmpty()) - config = QDir::homePath() + "/" + ".config"; - return config + "/autostart"; - } + QProcessEnvironment env = QProcessEnvironment::systemEnvironment(); + QString config = env.value("XDG_CONFIG_HOME"); + if (config.isEmpty()) + config = QDir::homePath() + "/" + ".config"; + return config + "/autostart"; +} - QString getAutostartFilePath(QString dir) - { - return dir + "/qTox - " + Settings::getInstance().getCurrentProfile() + - ".desktop"; - } +QString getAutostartFilePath(QString dir) +{ + return dir + "/qTox - " + Settings::getInstance().getCurrentProfile() + ".desktop"; +} - inline QString currentCommandLine() - { - return "\"" + QApplication::applicationFilePath() + "\" -p \"" + - Settings::getInstance().getCurrentProfile() + "\""; - } +inline QString currentCommandLine() +{ + return "\"" + QApplication::applicationFilePath() + "\" -p \"" + + Settings::getInstance().getCurrentProfile() + "\""; +} } bool Platform::setAutorun(bool on) { QString dirPath = getAutostartDirPath(); QFile desktop(getAutostartFilePath(dirPath)); - if (on) - { - if (!QDir().mkpath(dirPath) || - !desktop.open(QFile::WriteOnly | QFile::Truncate)) + if (on) { + if (!QDir().mkpath(dirPath) || !desktop.open(QFile::WriteOnly | QFile::Truncate)) return false; desktop.write("[Desktop Entry]\n"); desktop.write("Type=Application\n"); @@ -65,8 +61,7 @@ bool Platform::setAutorun(bool on) desktop.write("\n"); desktop.close(); return true; - } - else + } else return desktop.remove(); } @@ -75,4 +70,4 @@ bool Platform::getAutorun() return QFile(getAutostartFilePath(getAutostartDirPath())).exists(); } -#endif // defined(Q_OS_UNIX) && !defined(__APPLE__) && !defined(__MACH__) +#endif // defined(Q_OS_UNIX) && !defined(__APPLE__) && !defined(__MACH__) diff --git a/src/platform/camera/avfoundation.h b/src/platform/camera/avfoundation.h index 341f9da28..06b017b00 100644 --- a/src/platform/camera/avfoundation.h +++ b/src/platform/camera/avfoundation.h @@ -19,21 +19,20 @@ #ifndef AVFOUNDATION_H #define AVFOUNDATION_H +#include "src/video/videomode.h" +#include #include #include -#include -#include "src/video/videomode.h" #ifndef Q_OS_MACX #error "This file is only meant to be compiled for Mac OS X targets" #endif -namespace avfoundation -{ - const QString CAPTURE_SCREEN{"Capture screen"}; +namespace avfoundation { +const QString CAPTURE_SCREEN{"Capture screen"}; - QVector getDeviceModes(QString devName); - QVector> getDeviceList(); +QVector getDeviceModes(QString devName); +QVector> getDeviceList(); } #endif // AVFOUNDATION_H diff --git a/src/platform/camera/directshow.cpp b/src/platform/camera/directshow.cpp index 9bc22fd5c..dd32f1bdb 100644 --- a/src/platform/camera/directshow.cpp +++ b/src/platform/camera/directshow.cpp @@ -21,14 +21,14 @@ #include "directshow.h" +#include +#include +#include #include +#include #include #include -#include -#include #include -#include -#include /** * Most of this file is adapted from libavdevice's dshow.c, @@ -36,38 +36,38 @@ * stdout and is not part of the public API for some reason. */ -static char *wcharToUtf8(wchar_t *w) +static char* wcharToUtf8(wchar_t* w) { int l = WideCharToMultiByte(CP_UTF8, 0, w, -1, 0, 0, 0, 0); - char *s = new char[l]; + char* s = new char[l]; if (s) WideCharToMultiByte(CP_UTF8, 0, w, -1, s, l, 0, 0); return s; } -QVector> DirectShow::getDeviceList() +QVector> DirectShow::getDeviceList() { IMoniker* m = nullptr; - QVector> devices; + QVector> devices; ICreateDevEnum* devenum = nullptr; - if (CoCreateInstance(CLSID_SystemDeviceEnum, nullptr, CLSCTX_INPROC_SERVER, - IID_ICreateDevEnum, (void**) &devenum) != S_OK) + if (CoCreateInstance(CLSID_SystemDeviceEnum, nullptr, CLSCTX_INPROC_SERVER, IID_ICreateDevEnum, + (void**)&devenum) + != S_OK) return devices; IEnumMoniker* classenum = nullptr; - if (devenum->CreateClassEnumerator(CLSID_VideoInputDeviceCategory, - (IEnumMoniker**)&classenum, 0) != S_OK) + if (devenum->CreateClassEnumerator(CLSID_VideoInputDeviceCategory, (IEnumMoniker**)&classenum, 0) + != S_OK) return devices; - while (classenum->Next(1, &m, nullptr) == S_OK) - { + while (classenum->Next(1, &m, nullptr) == S_OK) { VARIANT var; IPropertyBag* bag = nullptr; LPMALLOC coMalloc = nullptr; IBindCtx* bindCtx = nullptr; LPOLESTR olestr = nullptr; - char *devIdString=nullptr, *devHumanName=nullptr; + char *devIdString = nullptr, *devHumanName = nullptr; if (CoGetMalloc(1, &coMalloc) != S_OK) goto fail; @@ -93,9 +93,9 @@ QVector> DirectShow::getDeviceList() goto fail; devHumanName = wcharToUtf8(var.bstrVal); - devices += {QString("video=")+devIdString, devHumanName}; + devices += {QString("video=") + devIdString, devHumanName}; -fail: + fail: if (olestr && coMalloc) coMalloc->Free(olestr); if (bindCtx) @@ -120,17 +120,17 @@ static IBaseFilter* getDevFilter(QString devName) IMoniker* m = nullptr; ICreateDevEnum* devenum = nullptr; - if (CoCreateInstance(CLSID_SystemDeviceEnum, nullptr, CLSCTX_INPROC_SERVER, - IID_ICreateDevEnum, (void**) &devenum) != S_OK) + if (CoCreateInstance(CLSID_SystemDeviceEnum, nullptr, CLSCTX_INPROC_SERVER, IID_ICreateDevEnum, + (void**)&devenum) + != S_OK) return devFilter; IEnumMoniker* classenum = nullptr; - if (devenum->CreateClassEnumerator(CLSID_VideoInputDeviceCategory, - (IEnumMoniker**)&classenum, 0) != S_OK) + if (devenum->CreateClassEnumerator(CLSID_VideoInputDeviceCategory, (IEnumMoniker**)&classenum, 0) + != S_OK) return devFilter; - while (classenum->Next(1, &m, nullptr) == S_OK) - { + while (classenum->Next(1, &m, nullptr) == S_OK) { LPMALLOC coMalloc = nullptr; IBindCtx* bindCtx = nullptr; LPOLESTR olestr = nullptr; @@ -156,7 +156,7 @@ static IBaseFilter* getDevFilter(QString devName) if (m->BindToObject(0, 0, IID_IBaseFilter, (void**)&devFilter) != S_OK) goto fail; -fail: + fail: if (olestr && coMalloc) coMalloc->Free(olestr); if (bindCtx) @@ -167,7 +167,7 @@ fail: classenum->Release(); if (!devFilter) - qWarning() << "Could't find the device "< DirectShow::getDeviceModes(QString devName) // The outter loop tries to find a valid output pin GUID category; DWORD r2; - IEnumPins *pins = nullptr; - IPin *pin; + IEnumPins* pins = nullptr; + IPin* pin; if (devFilter->EnumPins(&pins) != S_OK) return modes; - while (pins->Next(1, &pin, nullptr) == S_OK) - { - IKsPropertySet *p = nullptr; + while (pins->Next(1, &pin, nullptr) == S_OK) { + IKsPropertySet* p = nullptr; PIN_INFO info; pin->QueryPinInfo(&info); @@ -199,8 +198,8 @@ QVector DirectShow::getDeviceModes(QString devName) goto next; if (pin->QueryInterface(IID_IKsPropertySet, (void**)&p) != S_OK) goto next; - if (p->Get(AMPROPSETID_Pin, AMPROPERTY_PIN_CATEGORY, - nullptr, 0, &category, sizeof(GUID), &r2) != S_OK) + if (p->Get(AMPROPSETID_Pin, AMPROPERTY_PIN_CATEGORY, nullptr, 0, &category, sizeof(GUID), &r2) + != S_OK) goto next; if (!IsEqualGUID(category, PIN_CATEGORY_CAPTURE)) goto next; @@ -208,8 +207,8 @@ QVector DirectShow::getDeviceModes(QString devName) // Now we can list the video modes for the current pin // Prepare for another wall of spaghetti DIRECT SHOW QUALITY code { - IAMStreamConfig *config = nullptr; - VIDEO_STREAM_CONFIG_CAPS *vcaps = nullptr; + IAMStreamConfig* config = nullptr; + VIDEO_STREAM_CONFIG_CAPS* vcaps = nullptr; int size, n; if (pin->QueryInterface(IID_IAMStreamConfig, (void**)&config) != S_OK) goto next; @@ -219,8 +218,7 @@ QVector DirectShow::getDeviceModes(QString devName) assert(size == sizeof(VIDEO_STREAM_CONFIG_CAPS)); vcaps = new VIDEO_STREAM_CONFIG_CAPS; - for (int i = 0; i < n; ++i) - { + for (int i = 0; i < n; ++i) { AM_MEDIA_TYPE* type = nullptr; VideoMode mode; if (config->GetStreamCaps(i, &type, (BYTE*)vcaps) != S_OK) @@ -236,16 +234,16 @@ QVector DirectShow::getDeviceModes(QString devName) if (!modes.contains(mode)) modes.append(std::move(mode)); -nextformat: + nextformat: if (type->pbFormat) CoTaskMemFree(type->pbFormat); CoTaskMemFree(type); } -pinend: + pinend: config->Release(); delete vcaps; } -next: + next: if (p) p->Release(); pin->Release(); diff --git a/src/platform/camera/directshow.h b/src/platform/camera/directshow.h index 480368c5f..00479846c 100644 --- a/src/platform/camera/directshow.h +++ b/src/platform/camera/directshow.h @@ -21,19 +21,18 @@ #ifndef DIRECTSHOW_H #define DIRECTSHOW_H +#include "src/video/videomode.h" +#include #include #include -#include -#include "src/video/videomode.h" #ifndef Q_OS_WIN #error "This file is only meant to be compiled for Windows targets" #endif -namespace DirectShow -{ - QVector> getDeviceList(); - QVector getDeviceModes(QString devName); +namespace DirectShow { +QVector> getDeviceList(); +QVector getDeviceModes(QString devName); } #endif // DIRECTSHOW_H diff --git a/src/platform/camera/v4l2.cpp b/src/platform/camera/v4l2.cpp index c83be7701..4a25c0e5b 100644 --- a/src/platform/camera/v4l2.cpp +++ b/src/platform/camera/v4l2.cpp @@ -22,14 +22,14 @@ #include "v4l2.h" -#include -#include -#include -#include -#include -#include -#include #include +#include +#include +#include +#include +#include +#include +#include /** * Most of this file is adapted from libavdevice's v4l2.c, @@ -37,25 +37,25 @@ * stdout and is not part of the public API for some reason. */ -static std::map createPixFmtToQuality() +static std::map createPixFmtToQuality() { - std::map m; + std::map m; m[V4L2_PIX_FMT_H264] = 3; m[V4L2_PIX_FMT_MJPEG] = 2; m[V4L2_PIX_FMT_YUYV] = 1; return m; } -const std::map pixFmtToQuality = createPixFmtToQuality(); +const std::map pixFmtToQuality = createPixFmtToQuality(); -static std::map createPixFmtToName() +static std::map createPixFmtToName() { - std::map m; + std::map m; m[V4L2_PIX_FMT_H264] = QString("h264"); m[V4L2_PIX_FMT_MJPEG] = QString("mjpeg"); m[V4L2_PIX_FMT_YUYV] = QString("yuyv422"); return m; } -const std::map pixFmtToName = createPixFmtToName(); +const std::map pixFmtToName = createPixFmtToName(); static int deviceOpen(QString devName, int* error) { @@ -90,7 +90,8 @@ fail: return -1; } -static QVector getDeviceModeFramerates(int fd, unsigned w, unsigned h, uint32_t pixelFormat) +static QVector getDeviceModeFramerates(int fd, unsigned w, unsigned h, + uint32_t pixelFormat) { QVector rates; v4l2_frmivalenum vfve{}; @@ -105,7 +106,7 @@ static QVector getDeviceModeFramerates(int fd, unsigned w, unsig rate = vfve.discrete.denominator / vfve.discrete.numerator; if (!rates.contains(rate)) rates.append(rate); - break; + break; case V4L2_FRMSIZE_TYPE_CONTINUOUS: case V4L2_FRMSIZE_TYPE_STEPWISE: rate = vfve.stepwise.min.denominator / vfve.stepwise.min.numerator; @@ -129,34 +130,32 @@ QVector v4l2::getDeviceModes(QString devName) v4l2_fmtdesc vfd{}; vfd.type = V4L2_BUF_TYPE_VIDEO_CAPTURE; - while (!ioctl(fd, VIDIOC_ENUM_FMT, &vfd)) - { + while (!ioctl(fd, VIDIOC_ENUM_FMT, &vfd)) { vfd.index++; v4l2_frmsizeenum vfse{}; vfse.pixel_format = vfd.pixelformat; - while (!ioctl(fd, VIDIOC_ENUM_FRAMESIZES, &vfse)) - { + while (!ioctl(fd, VIDIOC_ENUM_FRAMESIZES, &vfse)) { VideoMode mode; mode.pixel_format = vfse.pixel_format; switch (vfse.type) { case V4L2_FRMSIZE_TYPE_DISCRETE: mode.width = vfse.discrete.width; mode.height = vfse.discrete.height; - break; + break; case V4L2_FRMSIZE_TYPE_CONTINUOUS: case V4L2_FRMSIZE_TYPE_STEPWISE: mode.width = vfse.stepwise.max_width; mode.height = vfse.stepwise.max_height; - break; + break; default: continue; } - QVector rates = getDeviceModeFramerates(fd, mode.width, mode.height, vfd.pixelformat); - for (unsigned short rate : rates) - { + QVector rates = + getDeviceModeFramerates(fd, mode.width, mode.height, vfd.pixelformat); + for (unsigned short rate : rates) { mode.FPS = rate; if (!modes.contains(mode)) modes.append(std::move(mode)); @@ -173,7 +172,7 @@ QVector> v4l2::getDeviceList() QVector> devices; QVector deviceFiles; - DIR *dir = opendir("/dev"); + DIR* dir = opendir("/dev"); if (!dir) return devices; @@ -183,8 +182,7 @@ QVector> v4l2::getDeviceList() deviceFiles += QString("/dev/") + e->d_name; closedir(dir); - for (QString file : deviceFiles) - { + for (QString file : deviceFiles) { int fd = open(file.toStdString().c_str(), O_RDWR); if (fd < 0) continue; @@ -200,8 +198,7 @@ QVector> v4l2::getDeviceList() QString v4l2::getPixelFormatString(uint32_t pixel_format) { - if (pixFmtToName.find(pixel_format) == pixFmtToName.end()) - { + if (pixFmtToName.find(pixel_format) == pixFmtToName.end()) { qWarning() << "Pixel format not found"; return QString("unknown"); } @@ -210,14 +207,10 @@ QString v4l2::getPixelFormatString(uint32_t pixel_format) bool v4l2::betterPixelFormat(uint32_t a, uint32_t b) { - if (pixFmtToQuality.find(a) == pixFmtToQuality.end()) - { + if (pixFmtToQuality.find(a) == pixFmtToQuality.end()) { return false; - } - else if (pixFmtToQuality.find(b) == pixFmtToQuality.end()) - { + } else if (pixFmtToQuality.find(b) == pixFmtToQuality.end()) { return true; } - return pixFmtToQuality.at(a) > pixFmtToQuality.at(b); + return pixFmtToQuality.at(a) > pixFmtToQuality.at(b); } - diff --git a/src/platform/camera/v4l2.h b/src/platform/camera/v4l2.h index 8538bbfa8..8c1241e39 100644 --- a/src/platform/camera/v4l2.h +++ b/src/platform/camera/v4l2.h @@ -19,22 +19,20 @@ #ifndef V4L2_H #define V4L2_H +#include "src/video/videomode.h" +#include #include #include -#include -#include "src/video/videomode.h" #if !(defined(Q_OS_LINUX) || defined(Q_OS_FREEBSD)) #error "This file is only meant to be compiled for Linux or FreeBSD targets" #endif -namespace v4l2 -{ - QVector getDeviceModes(QString devName); - QVector> getDeviceList(); - QString getPixelFormatString(uint32_t pixel_format); - bool betterPixelFormat(uint32_t a, uint32_t b); +namespace v4l2 { +QVector getDeviceModes(QString devName); +QVector> getDeviceList(); +QString getPixelFormatString(uint32_t pixel_format); +bool betterPixelFormat(uint32_t a, uint32_t b); } #endif // V4L2_H - diff --git a/src/platform/capslock.h b/src/platform/capslock.h index a3d9347d9..4cd5b9fb2 100644 --- a/src/platform/capslock.h +++ b/src/platform/capslock.h @@ -23,9 +23,8 @@ #define PLATFORM_CAPSLOCK_H -namespace Platform -{ - bool capsLockEnabled(); +namespace Platform { +bool capsLockEnabled(); } #endif // PLATFORM_CAPSLOCK_H diff --git a/src/platform/capslock_osx.cpp b/src/platform/capslock_osx.cpp index 55e601d31..8ff1f45e0 100644 --- a/src/platform/capslock_osx.cpp +++ b/src/platform/capslock_osx.cpp @@ -27,4 +27,4 @@ bool Platform::capsLockEnabled() return false; } -#endif // defined(__APPLE__) && defined(__MACH__) +#endif // defined(__APPLE__) && defined(__MACH__) diff --git a/src/platform/capslock_win.cpp b/src/platform/capslock_win.cpp index 6437299ce..00a4c3785 100644 --- a/src/platform/capslock_win.cpp +++ b/src/platform/capslock_win.cpp @@ -19,12 +19,12 @@ #include #ifdef Q_OS_WIN32 -#include #include "src/platform/capslock.h" +#include bool Platform::capsLockEnabled() { return GetKeyState(VK_CAPITAL) == 1; } -#endif // Q_OS_WIN32 +#endif // Q_OS_WIN32 diff --git a/src/platform/capslock_x11.cpp b/src/platform/capslock_x11.cpp index ffd6bcabd..7fccd0031 100644 --- a/src/platform/capslock_x11.cpp +++ b/src/platform/capslock_x11.cpp @@ -19,8 +19,8 @@ #include #if defined(Q_OS_UNIX) && !defined(__APPLE__) && !defined(__MACH__) -#include #include "src/platform/capslock.h" +#include #undef KeyPress #undef KeyRelease #undef FocusIn @@ -28,10 +28,9 @@ bool Platform::capsLockEnabled() { - Display * d = XOpenDisplay((char*)0); + Display* d = XOpenDisplay((char*)0); bool caps_state = false; - if (d) - { + if (d) { unsigned n; XkbGetIndicatorState(d, XkbUseCoreKbd, &n); caps_state = (n & 0x01) == 1; @@ -41,4 +40,4 @@ bool Platform::capsLockEnabled() } -#endif // defined(Q_OS_UNIX) && !defined(__APPLE__) && !defined(__MACH__) +#endif // defined(Q_OS_UNIX) && !defined(__APPLE__) && !defined(__MACH__) diff --git a/src/platform/install_osx.cpp b/src/platform/install_osx.cpp index 2306c931e..7cc306d0a 100644 --- a/src/platform/install_osx.cpp +++ b/src/platform/install_osx.cpp @@ -20,35 +20,34 @@ #include "install_osx.h" #include -#include #include -#include #include #include +#include +#include #include #include void osx::moveToAppFolder() { - if (qApp->applicationDirPath() != "/Applications/qtox.app/Contents/MacOS") - { + if (qApp->applicationDirPath() != "/Applications/qtox.app/Contents/MacOS") { qDebug() << "OS X: Not in Applications folder"; QMessageBox AskInstall; AskInstall.setIcon(QMessageBox::Question); AskInstall.setWindowModality(Qt::ApplicationModal); AskInstall.setText("Move to Applications folder?"); - AskInstall.setInformativeText("I can move myself to the Applications folder, keeping your downloads folder less cluttered.\r\n"); - AskInstall.setStandardButtons(QMessageBox::Yes|QMessageBox::No); + AskInstall.setInformativeText("I can move myself to the Applications folder, keeping your " + "downloads folder less cluttered.\r\n"); + AskInstall.setStandardButtons(QMessageBox::Yes | QMessageBox::No); AskInstall.setDefaultButton(QMessageBox::Yes); - int AskInstallAttempt = AskInstall.exec(); //Actually ask the user + int AskInstallAttempt = AskInstall.exec(); // Actually ask the user - if (AskInstallAttempt == QMessageBox::Yes) - { - QProcess *sudoprocess = new QProcess; - QProcess *qtoxprocess = new QProcess; + if (AskInstallAttempt == QMessageBox::Yes) { + QProcess* sudoprocess = new QProcess; + QProcess* qtoxprocess = new QProcess; QString bindir = qApp->applicationDirPath(); QString appdir = bindir; @@ -59,7 +58,7 @@ void osx::moveToAppFolder() QString appdir_noqtox = appdir; appdir_noqtox.chop(8); - if ((appdir_noqtox + "qtox.app") != appdir) //quick safety check + if ((appdir_noqtox + "qtox.app") != appdir) // quick safety check { qDebug() << "OS X: Attmepted to delete non qTox directory!"; exit(EXIT_UPDATE_MACX_FAIL); @@ -67,51 +66,56 @@ void osx::moveToAppFolder() QDir old_app(appdir); - sudoprocess->start(sudo); //Where the magic actually happens, safety checks ^ + sudoprocess->start(sudo); // Where the magic actually happens, safety checks ^ sudoprocess->waitForFinished(); - if (old_app.removeRecursively()) //We've just deleted the running program + if (old_app.removeRecursively()) // We've just deleted the running program qDebug() << "OS X: Cleaned up old directory"; else qDebug() << "OS X: This should never happen, the directory failed to delete"; - if (fork() != 0) //Forking is required otherwise it won't actually cleanly launch + if (fork() != 0) // Forking is required otherwise it won't actually cleanly launch exit(EXIT_UPDATE_MACX); qtoxprocess->start(qtox); - exit(0); //Actually kills it + exit(0); // Actually kills it } } } -// migrateProfiles() is compatabilty code that can be removed down the line when the time seems right. +// migrateProfiles() is compatabilty code that can be removed down the line when the time seems +// right. void osx::migrateProfiles() { - QString oldPath = QDir::cleanPath(QStandardPaths::writableLocation(QStandardPaths::HomeLocation) + QDir::separator() + - "Library" + QDir::separator() + "Preferences" + QDir::separator() + "tox"); + QString oldPath = QDir::cleanPath(QStandardPaths::writableLocation(QStandardPaths::HomeLocation) + + QDir::separator() + "Library" + QDir::separator() + + "Preferences" + QDir::separator() + "tox"); QFileInfo checkDir(oldPath); - QString newPath = QDir::cleanPath(QStandardPaths::writableLocation(QStandardPaths::HomeLocation) + QDir::separator() - + "Library" + QDir::separator() + "Application Support" + QDir::separator() + "Tox"); + QString newPath = QDir::cleanPath(QStandardPaths::writableLocation(QStandardPaths::HomeLocation) + + QDir::separator() + "Library" + QDir::separator() + + "Application Support" + QDir::separator() + "Tox"); QDir dir; - if (!checkDir.exists() || !checkDir.isDir()) - { + if (!checkDir.exists() || !checkDir.isDir()) { qDebug() << "OS X: Old settings directory not detected"; return; } qDebug() << "OS X: Old settings directory detected migrating to default"; - if (!dir.rename(oldPath, newPath)) - { - qDebug() << "OS X: Profile migration failed. ~/Library/Application Support/Tox already exists. Using alternate migration method."; - QString OSXMigrater = "../Resources/OSX-Migrater.sh" ; + if (!dir.rename(oldPath, newPath)) { + qDebug() << "OS X: Profile migration failed. ~/Library/Application Support/Tox already " + "exists. Using alternate migration method."; + QString OSXMigrater = "../Resources/OSX-Migrater.sh"; QProcess::execute(OSXMigrater); QMessageBox MigrateProfile; MigrateProfile.setIcon(QMessageBox::Information); MigrateProfile.setWindowModality(Qt::ApplicationModal); MigrateProfile.setText("Alternate profile migration method used."); - MigrateProfile.setInformativeText("It has been detected that your profiles \nwhere migrated to the new settings directory; \nusing the alternate migration method. \n\nA backup can be found in your: \n/Users/[USER]/.Tox-Backup[DATE-TIME] \n\nJust in case. \r\n"); + MigrateProfile.setInformativeText( + "It has been detected that your profiles \nwhere migrated to the new settings " + "directory; \nusing the alternate migration method. \n\nA backup can be found in your: " + "\n/Users/[USER]/.Tox-Backup[DATE-TIME] \n\nJust in case. \r\n"); MigrateProfile.exec(); } } diff --git a/src/platform/install_osx.h b/src/platform/install_osx.h index 829a305b5..98f73e7ec 100644 --- a/src/platform/install_osx.h +++ b/src/platform/install_osx.h @@ -25,13 +25,13 @@ #error "This file is only meant to be compiled for Mac OSX targets" #endif -namespace osx -{ - static constexpr int EXIT_UPDATE_MACX = 218; // We track our state using unique exit codes when debugging - static constexpr int EXIT_UPDATE_MACX_FAIL = 216; +namespace osx { +static constexpr int EXIT_UPDATE_MACX = + 218; // We track our state using unique exit codes when debugging +static constexpr int EXIT_UPDATE_MACX_FAIL = 216; - void moveToAppFolder(); - void migrateProfiles(); +void moveToAppFolder(); +void migrateProfiles(); } #endif // INSTALLOSX_H diff --git a/src/platform/statusnotifier/closures.h b/src/platform/statusnotifier/closures.h index 4968e4999..b35343659 100644 --- a/src/platform/statusnotifier/closures.h +++ b/src/platform/statusnotifier/closures.h @@ -23,19 +23,15 @@ #ifndef __g_cclosure_user_marshal_MARSHAL_H__ #define __g_cclosure_user_marshal_MARSHAL_H__ -#include +#include G_BEGIN_DECLS /* BOOLEAN:INT,INT (closures.def:1) */ -extern void g_cclosure_user_marshal_BOOLEAN__INT_INT (GClosure *closure, - GValue *return_value, - guint n_param_values, - const GValue *param_values, - gpointer invocation_hint, - gpointer marshal_data); +extern void g_cclosure_user_marshal_BOOLEAN__INT_INT(GClosure* closure, GValue* return_value, + guint n_param_values, const GValue* param_values, + gpointer invocation_hint, gpointer marshal_data); G_END_DECLS #endif /* __g_cclosure_user_marshal_MARSHAL_H__ */ - diff --git a/src/platform/statusnotifier/enums.h b/src/platform/statusnotifier/enums.h index 7fa1e168a..c8d059f87 100644 --- a/src/platform/statusnotifier/enums.h +++ b/src/platform/statusnotifier/enums.h @@ -25,22 +25,18 @@ #include "statusnotifier.h" - -GType status_notifier_error_get_type (void); +GType status_notifier_error_get_type(void); #define TYPE_STATUS_NOTIFIER_ERROR (status_notifier_error_get_type()) -GType status_notifier_state_get_type (void); +GType status_notifier_state_get_type(void); #define TYPE_STATUS_NOTIFIER_STATE (status_notifier_state_get_type()) -GType status_notifier_icon_get_type (void); +GType status_notifier_icon_get_type(void); #define TYPE_STATUS_NOTIFIER_ICON (status_notifier_icon_get_type()) -GType status_notifier_category_get_type (void); +GType status_notifier_category_get_type(void); #define TYPE_STATUS_NOTIFIER_CATEGORY (status_notifier_category_get_type()) -GType status_notifier_status_get_type (void); +GType status_notifier_status_get_type(void); #define TYPE_STATUS_NOTIFIER_STATUS (status_notifier_status_get_type()) -GType status_notifier_scroll_orientation_get_type (void); +GType status_notifier_scroll_orientation_get_type(void); #define TYPE_STATUS_NOTIFIER_SCROLL_ORIENTATION (status_notifier_scroll_orientation_get_type()) G_END_DECLS #endif /* __STATUS_NOTIFIER_ENUMS_H__ */ - - - diff --git a/src/platform/statusnotifier/interfaces.h b/src/platform/statusnotifier/interfaces.h index 507bfa75d..3676211b2 100644 --- a/src/platform/statusnotifier/interfaces.h +++ b/src/platform/statusnotifier/interfaces.h @@ -25,13 +25,13 @@ G_BEGIN_DECLS -#define WATCHER_NAME "org.kde.StatusNotifierWatcher" -#define WATCHER_OBJECT "/StatusNotifierWatcher" -#define WATCHER_INTERFACE "org.kde.StatusNotifierWatcher" +#define WATCHER_NAME "org.kde.StatusNotifierWatcher" +#define WATCHER_OBJECT "/StatusNotifierWatcher" +#define WATCHER_INTERFACE "org.kde.StatusNotifierWatcher" -#define ITEM_NAME "org.kde.StatusNotifierItem" -#define ITEM_OBJECT "/StatusNotifierItem" -#define ITEM_INTERFACE "org.kde.StatusNotifierItem" +#define ITEM_NAME "org.kde.StatusNotifierItem" +#define ITEM_OBJECT "/StatusNotifierItem" +#define ITEM_INTERFACE "org.kde.StatusNotifierItem" static const gchar watcher_xml[] = "" diff --git a/src/platform/statusnotifier/statusnotifier.h b/src/platform/statusnotifier/statusnotifier.h index 3834064d5..cc9d4b91f 100644 --- a/src/platform/statusnotifier/statusnotifier.h +++ b/src/platform/statusnotifier/statusnotifier.h @@ -23,27 +23,30 @@ #ifndef __STATUS_NOTIFIER_H__ #define __STATUS_NOTIFIER_H__ -#include -#include -#include #include +#include +#include +#include G_BEGIN_DECLS -typedef struct _StatusNotifier StatusNotifier; -typedef struct _StatusNotifierPrivate StatusNotifierPrivate; -typedef struct _StatusNotifierClass StatusNotifierClass; +typedef struct _StatusNotifier StatusNotifier; +typedef struct _StatusNotifierPrivate StatusNotifierPrivate; +typedef struct _StatusNotifierClass StatusNotifierClass; -#define TYPE_STATUS_NOTIFIER (status_notifier_get_type ()) -#define STATUS_NOTIFIER(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), TYPE_STATUS_NOTIFIER, StatusNotifier)) -#define STATUS_NOTIFIER_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), TYPE_STATUS_NOTIFIER, StatusNotiferClass)) -#define IS_STATUS_NOTIFIER(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), TYPE_STATUS_NOTIFIER)) -#define IS_STATUS_NOTIFIER_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((obj), TYPE_STATUS_NOTIFIER)) -#define STATUS_NOTIFIER_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), TYPE_STATUS_NOTIFIER, StatusNotifierClass)) +#define TYPE_STATUS_NOTIFIER (status_notifier_get_type()) +#define STATUS_NOTIFIER(obj) \ + (G_TYPE_CHECK_INSTANCE_CAST((obj), TYPE_STATUS_NOTIFIER, StatusNotifier)) +#define STATUS_NOTIFIER_CLASS(klass) \ + (G_TYPE_CHECK_CLASS_CAST((klass), TYPE_STATUS_NOTIFIER, StatusNotiferClass)) +#define IS_STATUS_NOTIFIER(obj) (G_TYPE_CHECK_INSTANCE_TYPE((obj), TYPE_STATUS_NOTIFIER)) +#define IS_STATUS_NOTIFIER_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE((obj), TYPE_STATUS_NOTIFIER)) +#define STATUS_NOTIFIER_GET_CLASS(obj) \ + (G_TYPE_INSTANCE_GET_CLASS((obj), TYPE_STATUS_NOTIFIER, StatusNotifierClass)) -GType status_notifier_get_type (void) G_GNUC_CONST; +GType status_notifier_get_type(void) G_GNUC_CONST; -#define STATUS_NOTIFIER_ERROR g_quark_from_static_string ("StatusNotifier error") +#define STATUS_NOTIFIER_ERROR g_quark_from_static_string("StatusNotifier error") /** * StatusNotifierError: * @STATUS_NOTIFIER_ERROR_NO_CONNECTION: Failed to establish connection to @@ -58,8 +61,7 @@ GType status_notifier_get_type (void) G_GNUC_CONST; * Errors that can occur while trying to register the item. Note that errors * other the #StatusNotifierError might be returned. */ -typedef enum -{ +typedef enum { STATUS_NOTIFIER_ERROR_NO_CONNECTION = 0, STATUS_NOTIFIER_ERROR_NO_NAME, STATUS_NOTIFIER_ERROR_NO_WATCHER, @@ -82,8 +84,7 @@ typedef enum * State in which a #StatusNotifier item can be. See status_notifier_register() * for more */ -typedef enum -{ +typedef enum { STATUS_NOTIFIER_STATE_NOT_REGISTERED = 0, STATUS_NOTIFIER_STATE_REGISTERING, STATUS_NOTIFIER_STATE_REGISTERED, @@ -105,8 +106,7 @@ typedef enum * * Possible icons that can be used on a status notifier item. */ -typedef enum -{ +typedef enum { STATUS_NOTIFIER_ICON = 0, STATUS_NOTIFIER_ATTENTION_ICON, STATUS_NOTIFIER_OVERLAY_ICON, @@ -134,8 +134,7 @@ typedef enum * * The category of the status notifier item. */ -typedef enum -{ +typedef enum { STATUS_NOTIFIER_CATEGORY_APPLICATION_STATUS = 0, STATUS_NOTIFIER_CATEGORY_COMMUNICATIONS, STATUS_NOTIFIER_CATEGORY_SYSTEM_SERVICES, @@ -156,8 +155,7 @@ typedef enum * * The status of the status notifier item or its associated application. */ -typedef enum -{ +typedef enum { STATUS_NOTIFIER_STATUS_PASSIVE = 0, STATUS_NOTIFIER_STATUS_ACTIVE, STATUS_NOTIFIER_STATUS_NEEDS_ATTENTION @@ -172,8 +170,7 @@ typedef enum * The orientation of a scroll request performed on the representation of the * item in the visualization. */ -typedef enum -{ +typedef enum { STATUS_NOTIFIER_SCROLL_ORIENTATION_HORIZONTAL = 0, STATUS_NOTIFIER_SCROLL_ORIENTATION_VERTICAL } StatusNotifierScrollOrientation; @@ -182,7 +179,7 @@ struct _StatusNotifier { /*< private >*/ GObject parent; - StatusNotifierPrivate *priv; + StatusNotifierPrivate* priv; }; /** @@ -209,95 +206,44 @@ struct _StatusNotifierClass GObjectClass parent_class; /* signals */ - void (*registration_failed) (StatusNotifier *sn, - GError *error); + void (*registration_failed)(StatusNotifier* sn, GError* error); - gboolean (*context_menu) (StatusNotifier *sn, - gint x, - gint y); - gboolean (*activate) (StatusNotifier *sn, - gint x, - gint y); - gboolean (*secondary_activate) (StatusNotifier *sn, - gint x, - gint y); - gboolean (*scroll) (StatusNotifier *sn, - gint delta, - StatusNotifierScrollOrientation orientation); + gboolean (*context_menu)(StatusNotifier* sn, gint x, gint y); + gboolean (*activate)(StatusNotifier* sn, gint x, gint y); + gboolean (*secondary_activate)(StatusNotifier* sn, gint x, gint y); + gboolean (*scroll)(StatusNotifier* sn, gint delta, StatusNotifierScrollOrientation orientation); }; -StatusNotifier * status_notifier_new_from_pixbuf ( - const gchar *id, - StatusNotifierCategory category, - GdkPixbuf *pixbuf); -StatusNotifier * status_notifier_new_from_icon_name ( - const gchar *id, - StatusNotifierCategory category, - const gchar *icon_name); -const gchar * status_notifier_get_id ( - StatusNotifier *sn); -StatusNotifierCategory status_notifier_get_category ( - StatusNotifier *sn); -void status_notifier_set_from_pixbuf ( - StatusNotifier *sn, - StatusNotifierIcon icon, - GdkPixbuf *pixbuf); -void status_notifier_set_from_icon_name ( - StatusNotifier *sn, - StatusNotifierIcon icon, - const gchar *icon_name); -gboolean status_notifier_has_pixbuf ( - StatusNotifier *sn, - StatusNotifierIcon icon); -GdkPixbuf * status_notifier_get_pixbuf ( - StatusNotifier *sn, - StatusNotifierIcon icon); -gchar * status_notifier_get_icon_name ( - StatusNotifier *sn, - StatusNotifierIcon icon); -void status_notifier_set_attention_movie_name ( - StatusNotifier *sn, - const gchar *movie_name); -gchar * status_notifier_get_attention_movie_name ( - StatusNotifier *sn); -void status_notifier_set_title ( - StatusNotifier *sn, - const gchar *title); -gchar * status_notifier_get_title ( - StatusNotifier *sn); -void status_notifier_set_status ( - StatusNotifier *sn, - StatusNotifierStatus status); -StatusNotifierStatus status_notifier_get_status ( - StatusNotifier *sn); -void status_notifier_set_window_id ( - StatusNotifier *sn, - guint32 window_id); -guint32 status_notifier_get_window_id ( - StatusNotifier *sn); -void status_notifier_freeze_tooltip ( - StatusNotifier *sn); -void status_notifier_thaw_tooltip ( - StatusNotifier *sn); -void status_notifier_set_tooltip ( - StatusNotifier *sn, - const gchar *icon_name, - const gchar *title, - const gchar *body); -void status_notifier_set_tooltip_title ( - StatusNotifier *sn, - const gchar *title); -gchar * status_notifier_get_tooltip_title ( - StatusNotifier *sn); -void status_notifier_set_tooltip_body ( - StatusNotifier *sn, - const gchar *body); -gchar * status_notifier_get_tooltip_body ( - StatusNotifier *sn); -void status_notifier_register ( - StatusNotifier *sn); -StatusNotifierState status_notifier_get_state ( - StatusNotifier *sn); +StatusNotifier* status_notifier_new_from_pixbuf(const gchar* id, StatusNotifierCategory category, + GdkPixbuf* pixbuf); +StatusNotifier* status_notifier_new_from_icon_name(const gchar* id, StatusNotifierCategory category, + const gchar* icon_name); +const gchar* status_notifier_get_id(StatusNotifier* sn); +StatusNotifierCategory status_notifier_get_category(StatusNotifier* sn); +void status_notifier_set_from_pixbuf(StatusNotifier* sn, StatusNotifierIcon icon, GdkPixbuf* pixbuf); +void status_notifier_set_from_icon_name(StatusNotifier* sn, StatusNotifierIcon icon, + const gchar* icon_name); +gboolean status_notifier_has_pixbuf(StatusNotifier* sn, StatusNotifierIcon icon); +GdkPixbuf* status_notifier_get_pixbuf(StatusNotifier* sn, StatusNotifierIcon icon); +gchar* status_notifier_get_icon_name(StatusNotifier* sn, StatusNotifierIcon icon); +void status_notifier_set_attention_movie_name(StatusNotifier* sn, const gchar* movie_name); +gchar* status_notifier_get_attention_movie_name(StatusNotifier* sn); +void status_notifier_set_title(StatusNotifier* sn, const gchar* title); +gchar* status_notifier_get_title(StatusNotifier* sn); +void status_notifier_set_status(StatusNotifier* sn, StatusNotifierStatus status); +StatusNotifierStatus status_notifier_get_status(StatusNotifier* sn); +void status_notifier_set_window_id(StatusNotifier* sn, guint32 window_id); +guint32 status_notifier_get_window_id(StatusNotifier* sn); +void status_notifier_freeze_tooltip(StatusNotifier* sn); +void status_notifier_thaw_tooltip(StatusNotifier* sn); +void status_notifier_set_tooltip(StatusNotifier* sn, const gchar* icon_name, const gchar* title, + const gchar* body); +void status_notifier_set_tooltip_title(StatusNotifier* sn, const gchar* title); +gchar* status_notifier_get_tooltip_title(StatusNotifier* sn); +void status_notifier_set_tooltip_body(StatusNotifier* sn, const gchar* body); +gchar* status_notifier_get_tooltip_body(StatusNotifier* sn); +void status_notifier_register(StatusNotifier* sn); +StatusNotifierState status_notifier_get_state(StatusNotifier* sn); G_END_DECLS diff --git a/src/platform/timer.h b/src/platform/timer.h index 542775b23..9a429f1f3 100644 --- a/src/platform/timer.h +++ b/src/platform/timer.h @@ -25,9 +25,8 @@ #include -namespace Platform -{ - uint32_t getIdleTime(); +namespace Platform { +uint32_t getIdleTime(); } #endif // PLATFORM_TIMER_H diff --git a/src/platform/timer_osx.cpp b/src/platform/timer_osx.cpp index 1ff788074..f78f494ed 100644 --- a/src/platform/timer_osx.cpp +++ b/src/platform/timer_osx.cpp @@ -26,8 +26,8 @@ #include #if defined(__APPLE__) && defined(__MACH__) #include "src/platform/timer.h" -#include #include +#include uint32_t Platform::getIdleTime() { @@ -38,8 +38,7 @@ uint32_t Platform::getIdleTime() CFTypeRef property; uint64_t idleTime_ns = 0; - if (!service) - { + if (!service) { mach_port_t master; IOMasterPort(MACH_PORT_NULL, &master); service = IOServiceGetMatchingService(master, IOServiceMatching("IOHIDSystem")); @@ -52,4 +51,4 @@ uint32_t Platform::getIdleTime() return idleTime_ns / 1000000; } -#endif // defined(__APPLE__) && defined(__MACH__) +#endif // defined(__APPLE__) && defined(__MACH__) diff --git a/src/platform/timer_win.cpp b/src/platform/timer_win.cpp index 1f386855a..1879bb410 100644 --- a/src/platform/timer_win.cpp +++ b/src/platform/timer_win.cpp @@ -24,11 +24,11 @@ uint32_t Platform::getIdleTime() { - LASTINPUTINFO info = { 0, 0 }; + LASTINPUTINFO info = {0, 0}; info.cbSize = sizeof(info); if (GetLastInputInfo(&info)) return GetTickCount() - info.dwTime; return 0; } -#endif // Q_OS_WIN32 +#endif // Q_OS_WIN32 diff --git a/src/platform/timer_x11.cpp b/src/platform/timer_x11.cpp index a3a4450ef..269687325 100644 --- a/src/platform/timer_x11.cpp +++ b/src/platform/timer_x11.cpp @@ -17,37 +17,33 @@ #include #if defined(Q_OS_UNIX) && !defined(__APPLE__) && !defined(__MACH__) -#include #include "src/platform/timer.h" +#include #include uint32_t Platform::getIdleTime() { uint32_t idleTime = 0; - Display *display = XOpenDisplay(NULL); - if (!display) - { + Display* display = XOpenDisplay(NULL); + if (!display) { qDebug() << "XOpenDisplay(NULL) failed"; return 0; } int32_t x11event = 0, x11error = 0; static int32_t hasExtension = XScreenSaverQueryExtension(display, &x11event, &x11error); - if (hasExtension) - { - XScreenSaverInfo *info = XScreenSaverAllocInfo(); - if (info) - { + if (hasExtension) { + XScreenSaverInfo* info = XScreenSaverAllocInfo(); + if (info) { XScreenSaverQueryInfo(display, DefaultRootWindow(display), info); idleTime = info->idle; XFree(info); - } - else + } else qDebug() << "XScreenSaverAllocInfo() failed"; } XCloseDisplay(display); return idleTime; } -#endif // Q_OS_UNIX +#endif // Q_OS_UNIX diff --git a/src/video/cameradevice.cpp b/src/video/cameradevice.cpp index abf7c1dd0..a186311f4 100644 --- a/src/video/cameradevice.cpp +++ b/src/video/cameradevice.cpp @@ -17,13 +17,13 @@ along with qTox. If not, see . */ -#include #include +#include #include #include extern "C" { -#include #include +#include } #include "cameradevice.h" #include "src/persistence/settings.h" @@ -67,8 +67,10 @@ QMutex CameraDevice::openDeviceLock, CameraDevice::iformatLock; AVInputFormat* CameraDevice::iformat{nullptr}; AVInputFormat* CameraDevice::idesktopFormat{nullptr}; -CameraDevice::CameraDevice(const QString &devName, AVFormatContext *context) - : devName{devName}, context{context}, refcount{1} +CameraDevice::CameraDevice(const QString& devName, AVFormatContext* context) + : devName{devName} + , context{context} + , refcount{1} { } @@ -82,33 +84,27 @@ CameraDevice* CameraDevice::open(QString devName, AVDictionary** options) goto out; AVInputFormat* format; - if (devName.startsWith("x11grab#")) - { + if (devName.startsWith("x11grab#")) { devName = devName.mid(8); format = idesktopFormat; - } - else if (devName.startsWith("gdigrab#")) - { + } else if (devName.startsWith("gdigrab#")) { devName = devName.mid(8); format = idesktopFormat; - } - else - { + } else { format = iformat; } if (avformat_open_input(&fctx, devName.toStdString().c_str(), format, options) < 0) goto out; - // Fix avformat_find_stream_info hanging on garbage input +// Fix avformat_find_stream_info hanging on garbage input #if FF_API_PROBESIZE_32 aduration = fctx->max_analyze_duration2 = 0; #else aduration = fctx->max_analyze_duration = 0; #endif - if (avformat_find_stream_info(fctx, NULL) < 0) - { + if (avformat_find_stream_info(fctx, NULL) < 0) { avformat_close_input(&fctx); goto out; } @@ -144,25 +140,21 @@ CameraDevice* CameraDevice::open(QString devName, VideoMode mode) if (!getDefaultInputFormat()) return nullptr; - if (devName == "none") - { + if (devName == "none") { qDebug() << "Tried to open the null device"; return nullptr; } AVDictionary* options = nullptr; - if (!iformat); + if (!iformat) + ; #if USING_V4L - else if (devName.startsWith("x11grab#")) - { + else if (devName.startsWith("x11grab#")) { QSize screen; - if (mode.width && mode.height) - { + if (mode.width && mode.height) { screen.setWidth(mode.width); screen.setHeight(mode.height); - } - else - { + } else { QScreen* defaultScreen = QApplication::primaryScreen(); qreal pixRatio; @@ -175,10 +167,12 @@ CameraDevice* CameraDevice::open(QString devName, VideoMode mode) screen = defaultScreen->size(); // Workaround https://trac.ffmpeg.org/ticket/4574 by choping 1 px bottom and right // Actually, let's chop two pixels, toxav hates odd resolutions (off by one stride) - screen.setWidth((screen.width() * pixRatio)-2); - screen.setHeight((screen.height() * pixRatio)-2); + screen.setWidth((screen.width() * pixRatio) - 2); + screen.setHeight((screen.height() * pixRatio) - 2); } - av_dict_set(&options, "video_size", QString("%1x%2").arg(screen.width()).arg(screen.height()).toStdString().c_str(), 0); + av_dict_set(&options, "video_size", + QString("%1x%2").arg(screen.width()).arg(screen.height()).toStdString().c_str(), + 0); devName += QString("+%1,%2").arg(QString().setNum(mode.x), QString().setNum(mode.y)); int FPS = 5; @@ -186,50 +180,43 @@ CameraDevice* CameraDevice::open(QString devName, VideoMode mode) FPS = mode.FPS; av_dict_set(&options, "framerate", QString().setNum(FPS).toStdString().c_str(), 0); - } - else if (iformat->name == QString("video4linux2,v4l2") && mode) - { - av_dict_set(&options, "video_size", QString("%1x%2").arg(mode.width).arg(mode.height).toStdString().c_str(), 0); + } else if (iformat->name == QString("video4linux2,v4l2") && mode) { + av_dict_set(&options, "video_size", + QString("%1x%2").arg(mode.width).arg(mode.height).toStdString().c_str(), 0); av_dict_set(&options, "framerate", QString().setNum(mode.FPS).toStdString().c_str(), 0); - const char *pixel_format = v4l2::getPixelFormatString(mode.pixel_format).toStdString().c_str(); - if (strncmp(pixel_format, "unknown", 7) != 0) - { + const char* pixel_format = v4l2::getPixelFormatString(mode.pixel_format).toStdString().c_str(); + if (strncmp(pixel_format, "unknown", 7) != 0) { av_dict_set(&options, "pixel_format", pixel_format, 0); } } #endif #ifdef Q_OS_WIN - else if (devName.startsWith("gdigrab#")) - { + else if (devName.startsWith("gdigrab#")) { av_dict_set(&options, "framerate", QString().setNum(5).toStdString().c_str(), 0); av_dict_set(&options, "offset_x", QString().setNum(mode.x).toStdString().c_str(), 0); av_dict_set(&options, "offset_y", QString().setNum(mode.y).toStdString().c_str(), 0); - av_dict_set(&options, "video_size", QString("%1x%2").arg(mode.width).arg(mode.height).toStdString().c_str(), 0); - } - else if (iformat->name == QString("dshow") && mode) - { - av_dict_set(&options, "video_size", QString("%1x%2").arg(mode.width).arg(mode.height).toStdString().c_str(), 0); + av_dict_set(&options, "video_size", + QString("%1x%2").arg(mode.width).arg(mode.height).toStdString().c_str(), 0); + } else if (iformat->name == QString("dshow") && mode) { + av_dict_set(&options, "video_size", + QString("%1x%2").arg(mode.width).arg(mode.height).toStdString().c_str(), 0); av_dict_set(&options, "framerate", QString().setNum(mode.FPS).toStdString().c_str(), 0); } #endif #ifdef Q_OS_OSX - else if (iformat->name == QString("avfoundation")) - { - if (mode) - { - av_dict_set(&options, "video_size", QString("%1x%2").arg(mode.width).arg(mode.height).toStdString().c_str(), 0); + else if (iformat->name == QString("avfoundation")) { + if (mode) { + av_dict_set(&options, "video_size", + QString("%1x%2").arg(mode.width).arg(mode.height).toStdString().c_str(), 0); av_dict_set(&options, "framerate", QString().setNum(mode.FPS).toStdString().c_str(), 0); - } - else if (devName.startsWith(avfoundation::CAPTURE_SCREEN)) - { + } else if (devName.startsWith(avfoundation::CAPTURE_SCREEN)) { av_dict_set(&options, "framerate", QString().setNum(5).toStdString().c_str(), 0); av_dict_set_int(&options, "capture_cursor", 1, 0); av_dict_set_int(&options, "capture_mouse_clicks", 1, 0); } } #endif - else if (mode) - { + else if (mode) { qWarning() << "Video mode-setting not implemented for input " << iformat->name; Q_UNUSED(mode); } @@ -281,42 +268,35 @@ QVector> CameraDevice::getRawDeviceListGeneric() return devices; // Alloc an input device context - AVFormatContext *s; + AVFormatContext* s; if (!(s = avformat_alloc_context())) return devices; - if (!iformat->priv_class || !AV_IS_INPUT_DEVICE(iformat->priv_class->category)) - { + if (!iformat->priv_class || !AV_IS_INPUT_DEVICE(iformat->priv_class->category)) { avformat_free_context(s); return devices; } s->iformat = iformat; - if (s->iformat->priv_data_size > 0) - { + if (s->iformat->priv_data_size > 0) { s->priv_data = av_mallocz(s->iformat->priv_data_size); - if (!s->priv_data) - { + if (!s->priv_data) { avformat_free_context(s); return devices; } - if (s->iformat->priv_class) - { - *(const AVClass**)s->priv_data= s->iformat->priv_class; + if (s->iformat->priv_class) { + *(const AVClass**)s->priv_data = s->iformat->priv_class; av_opt_set_defaults(s->priv_data); } - } - else - { + } else { s->priv_data = NULL; } // List the devices for this context AVDeviceInfoList* devlist = nullptr; - AVDictionary *tmp = nullptr; + AVDictionary* tmp = nullptr; av_dict_copy(&tmp, nullptr, 0); - if (av_opt_set_dict2(s, &tmp, AV_OPT_SEARCH_CHILDREN) < 0) - { + if (av_opt_set_dict2(s, &tmp, AV_OPT_SEARCH_CHILDREN) < 0) { av_dict_free(&tmp); avformat_free_context(s); return devices; @@ -324,16 +304,14 @@ QVector> CameraDevice::getRawDeviceListGeneric() avdevice_list_devices(s, &devlist); av_dict_free(&tmp); avformat_free_context(s); - if (!devlist) - { + if (!devlist) { qWarning() << "avdevice_list_devices failed"; return devices; } // Convert the list to a QVector devices.resize(devlist->nb_devices); - for (int i = 0; i < devlist->nb_devices; ++i) - { + for (int i = 0; i < devlist->nb_devices; ++i) { AVDeviceInfo* dev = devlist->devices[i]; devices[i].first = dev->device_name; devices[i].second = dev->device_description; @@ -354,9 +332,10 @@ QVector> CameraDevice::getDeviceList() devices.append({"none", QObject::tr("None", "No camera device set")}); if (!getDefaultInputFormat()) - return devices; + return devices; - if (!iformat); + if (!iformat) + ; #ifdef Q_OS_WIN else if (iformat->name == QString("dshow")) devices += DirectShow::getDeviceList(); @@ -372,10 +351,8 @@ QVector> CameraDevice::getDeviceList() else devices += getRawDeviceListGeneric(); - if (idesktopFormat) - { - if (idesktopFormat->name == QString("x11grab")) - { + if (idesktopFormat) { + if (idesktopFormat->name == QString("x11grab")) { QString dev = "x11grab#"; QByteArray display = qgetenv("DISPLAY"); @@ -384,10 +361,13 @@ QVector> CameraDevice::getDeviceList() else dev += display.constData(); - devices.push_back(QPair{dev, QObject::tr("Desktop", "Desktop as a camera input for screen sharing")}); + devices.push_back(QPair{ + dev, QObject::tr("Desktop", "Desktop as a camera input for screen sharing")}); } if (idesktopFormat->name == QString("gdigrab")) - devices.push_back(QPair{"gdigrab#desktop", QObject::tr("Desktop", "Desktop as a camera input for screen sharing")}); + devices.push_back(QPair{ + "gdigrab#desktop", + QObject::tr("Desktop", "Desktop as a camera input for screen sharing")}); } return devices; @@ -406,7 +386,7 @@ QString CameraDevice::getDefaultDeviceName() return defaultdev; QVector> devlist = getDeviceList(); - for (const QPair& device : devlist) + for (const QPair& device : devlist) if (defaultdev == device.first) return defaultdev; @@ -421,7 +401,7 @@ QString CameraDevice::getDefaultDeviceName() * @param devName Device name to check. * @return True, if device is screen, false otherwise. */ -bool CameraDevice::isScreen(const QString &devName) +bool CameraDevice::isScreen(const QString& devName) { return devName.startsWith("x11grab") || devName.startsWith("gdigrab"); } @@ -435,8 +415,7 @@ QVector CameraDevice::getScreenModes() QList screens = QApplication::screens(); QVector result; - std::for_each(screens.begin(), screens.end(), [&result](QScreen *s) - { + std::for_each(screens.begin(), screens.end(), [&result](QScreen* s) { QRect rect = s->geometry(); QPoint p = rect.topLeft(); @@ -446,7 +425,8 @@ QVector CameraDevice::getScreenModes() qreal pixRatio = 1.0; #endif - VideoMode mode(rect.width() * pixRatio, rect.height() * pixRatio, p.x() * pixRatio, p.y() * pixRatio); + VideoMode mode(rect.width() * pixRatio, rect.height() * pixRatio, p.x() * pixRatio, + p.y() * pixRatio); result.push_back(mode); }); @@ -462,7 +442,8 @@ QVector CameraDevice::getVideoModes(QString devName) { Q_UNUSED(devName); - if (!iformat); + if (!iformat) + ; else if (isScreen(devName)) return getScreenModes(); #ifdef Q_OS_WIN @@ -478,7 +459,7 @@ QVector CameraDevice::getVideoModes(QString devName) return avfoundation::getDeviceModes(devName); #endif else - qWarning() << "Video mode listing not implemented for input "<name; + qWarning() << "Video mode listing not implemented for input " << iformat->name; return {}; } @@ -507,9 +488,9 @@ QString CameraDevice::getPixelFormatString(uint32_t pixel_format) bool CameraDevice::betterPixelFormat(uint32_t a, uint32_t b) { #if USING_V4L - return v4l2::betterPixelFormat(a, b); + return v4l2::betterPixelFormat(a, b); #else - return false; + return false; #endif } @@ -525,7 +506,7 @@ bool CameraDevice::getDefaultInputFormat() avdevice_register_all(); - // Desktop capture input formats +// Desktop capture input formats #if USING_V4L idesktopFormat = av_find_input_format("x11grab"); #endif @@ -533,7 +514,7 @@ bool CameraDevice::getDefaultInputFormat() idesktopFormat = av_find_input_format("gdigrab"); #endif - // Webcam input formats +// Webcam input formats #if USING_V4L if ((iformat = av_find_input_format("v4l2"))) return true; diff --git a/src/video/cameradevice.h b/src/video/cameradevice.h index fbb769996..c654183a7 100644 --- a/src/video/cameradevice.h +++ b/src/video/cameradevice.h @@ -21,12 +21,12 @@ #ifndef CAMERADEVICE_H #define CAMERADEVICE_H +#include "videomode.h" #include -#include #include +#include #include #include -#include "videomode.h" struct AVFormatContext; struct AVInputFormat; @@ -48,13 +48,13 @@ public: static QString getDefaultDeviceName(); - static bool isScreen(const QString &devName); + static bool isScreen(const QString& devName); private: - CameraDevice(const QString &devName, AVFormatContext *context); + CameraDevice(const QString& devName, AVFormatContext* context); static CameraDevice* open(QString devName, AVDictionary** options); static bool getDefaultInputFormat(); - static QVector > getRawDeviceListGeneric(); + static QVector> getRawDeviceListGeneric(); static QVector getScreenModes(); public: @@ -65,7 +65,7 @@ private: std::atomic_int refcount; static QHash openDevices; static QMutex openDeviceLock, iformatLock; - static AVInputFormat* iformat, *idesktopFormat; + static AVInputFormat *iformat, *idesktopFormat; }; #endif // CAMERADEVICE_H diff --git a/src/video/camerasource.cpp b/src/video/camerasource.cpp index df1f61dc6..ddf78eca2 100644 --- a/src/video/camerasource.cpp +++ b/src/video/camerasource.cpp @@ -23,16 +23,16 @@ extern "C" { #include #include } -#include -#include -#include -#include -#include -#include -#include "src/persistence/settings.h" -#include "camerasource.h" #include "cameradevice.h" +#include "camerasource.h" #include "videoframe.h" +#include "src/persistence/settings.h" +#include +#include +#include +#include +#include +#include /** * @class CameraSource @@ -58,7 +58,8 @@ extern "C" { * @brief Short name of the device for CameraDevice's open(QString) * * @var CameraDevice* CameraSource::device - * @brief Non-owning pointer to an open CameraDevice, or nullptr. Not atomic, synced with memfences when becomes null. + * @brief Non-owning pointer to an open CameraDevice, or nullptr. Not atomic, synced with memfences + * when becomes null. * * @var VideoMode CameraSource::mode * @brief What mode we tried to open the device in, all zeros means default mode @@ -88,9 +89,15 @@ extern "C" { CameraSource* CameraSource::instance{nullptr}; CameraSource::CameraSource() - : deviceName{"none"}, device{nullptr}, mode(VideoMode()), - cctx{nullptr}, cctxOrig{nullptr}, videoStreamIndex{-1}, - _isOpen{false}, streamBlocker{false}, subscriptions{0} + : deviceName{"none"} + , device{nullptr} + , mode(VideoMode()) + , cctx{nullptr} + , cctxOrig{nullptr} + , videoStreamIndex{-1} + , _isOpen{false} + , streamBlocker{false} + , subscriptions{0} { subscriptions = 0; av_register_all(); @@ -109,8 +116,7 @@ CameraSource& CameraSource::getInstance() void CameraSource::destroyInstance() { - if (instance) - { + if (instance) { delete instance; instance = nullptr; } @@ -131,8 +137,7 @@ void CameraSource::open(const QString& deviceName) { bool isScreen = CameraDevice::isScreen(deviceName); VideoMode mode = VideoMode(Settings::getInstance().getScreenRegion()); - if (!isScreen) - { + if (!isScreen) { mode = VideoMode(Settings::getInstance().getCamVideoRes()); mode.FPS = Settings::getInstance().getCamVideoFPS(); } @@ -144,8 +149,7 @@ void CameraSource::open(const QString& DeviceName, VideoMode Mode) { QWriteLocker locker{&streamMutex}; - if (DeviceName == deviceName && Mode == mode) - { + if (DeviceName == deviceName && Mode == mode) { return; } @@ -179,8 +183,7 @@ CameraSource::~CameraSource() { QWriteLocker locker{&streamMutex}; - if (!_isOpen) - { + if (!_isOpen) { return; } @@ -192,8 +195,7 @@ CameraSource::~CameraSource() if (cctxOrig) avcodec_close(cctxOrig); - if (device) - { + if (device) { for (int i = 0; i < subscriptions; ++i) device->close(); @@ -211,20 +213,17 @@ bool CameraSource::subscribe() { QWriteLocker locker{&streamMutex}; - if (!_isOpen) - { + if (!_isOpen) { ++subscriptions; return true; } - if (openDevice()) - { + if (openDevice()) { ++subscriptions; return true; - } - else - { - while (device && !device->close()) {} + } else { + while (device && !device->close()) { + } device = nullptr; cctx = cctxOrig = nullptr; videoStreamIndex = -1; @@ -236,24 +235,19 @@ void CameraSource::unsubscribe() { QWriteLocker locker{&streamMutex}; - if (!_isOpen) - { + if (!_isOpen) { --subscriptions; return; } - if (!device) - { + if (!device) { qWarning() << "Unsubscribing with zero subscriber"; return; } - if (subscriptions - 1 == 0) - { + if (subscriptions - 1 == 0) { closeDevice(); - } - else - { + } else { device->close(); } subscriptions--; @@ -268,8 +262,7 @@ bool CameraSource::openDevice() { qDebug() << "Opening device " << deviceName; - if (device) - { + if (device) { device->open(); return true; } @@ -278,8 +271,7 @@ bool CameraSource::openDevice() AVCodec* codec; device = CameraDevice::open(deviceName, mode); - if (!device) - { + if (!device) { qWarning() << "Failed to open device!"; return false; } @@ -290,17 +282,14 @@ bool CameraSource::openDevice() device->open(); // Find the first video stream - for (unsigned i = 0; i < device->context->nb_streams; ++i) - { - if (device->context->streams[i]->codec->codec_type == AVMEDIA_TYPE_VIDEO) - { + for (unsigned i = 0; i < device->context->nb_streams; ++i) { + if (device->context->streams[i]->codec->codec_type == AVMEDIA_TYPE_VIDEO) { videoStreamIndex = i; break; } } - if (videoStreamIndex == -1) - { + if (videoStreamIndex == -1) { qWarning() << "Video stream not found"; return false; } @@ -308,16 +297,14 @@ bool CameraSource::openDevice() // Get a pointer to the codec context for the video stream cctxOrig = device->context->streams[videoStreamIndex]->codec; codec = avcodec_find_decoder(cctxOrig->codec_id); - if (!codec) - { + if (!codec) { qWarning() << "Codec not found"; return false; } // Copy context, since we apparently aren't allowed to use the original cctx = avcodec_alloc_context3(codec); - if (avcodec_copy_context(cctx, cctxOrig) != 0) - { + if (avcodec_copy_context(cctx, cctxOrig) != 0) { qWarning() << "Can't copy context"; return false; } @@ -325,8 +312,7 @@ bool CameraSource::openDevice() cctx->refcounted_frames = 1; // Open codec - if (avcodec_open2(cctx, codec, nullptr)<0) - { + if (avcodec_open2(cctx, codec, nullptr) < 0) { qWarning() << "Can't open codec"; avcodec_free_context(&cctx); return false; @@ -362,7 +348,8 @@ void CameraSource::closeDevice() avcodec_free_context(&cctx); avcodec_close(cctxOrig); cctxOrig = nullptr; - while (device && !device->close()) {} + while (device && !device->close()) { + } device = nullptr; } @@ -372,8 +359,7 @@ void CameraSource::closeDevice() */ void CameraSource::stream() { - auto streamLoop = [=]() - { + auto streamLoop = [=]() { AVFrame* frame = av_frame_alloc(); if (!frame) return; @@ -383,8 +369,7 @@ void CameraSource::stream() return; // Only keep packets from the right stream; - if (packet.stream_index == videoStreamIndex) - { + if (packet.stream_index == videoStreamIndex) { // Decode video frame int frameFinished; avcodec_decode_video2(cctx, frame, &frameFinished, &packet); @@ -395,8 +380,8 @@ void CameraSource::stream() emit frameAvailable(vframe->trackFrame()); } - // Free the packet that was allocated by av_read_frame - av_packet_unref(&packet); + // Free the packet that was allocated by av_read_frame + av_packet_unref(&packet); }; forever @@ -404,8 +389,7 @@ void CameraSource::stream() QReadLocker locker{&streamMutex}; // Exit if device is no longer valid - if(!device) - { + if (!device) { break; } diff --git a/src/video/camerasource.h b/src/video/camerasource.h index fc06f8409..b9092dda9 100644 --- a/src/video/camerasource.h +++ b/src/video/camerasource.h @@ -20,14 +20,14 @@ #ifndef CAMERA_H #define CAMERA_H -#include -#include -#include -#include -#include -#include -#include "src/video/videosource.h" #include "src/video/videomode.h" +#include "src/video/videosource.h" +#include +#include +#include +#include +#include +#include class CameraDevice; struct AVCodecContext; @@ -64,7 +64,7 @@ private: QString deviceName; CameraDevice* device; VideoMode mode; - AVCodecContext* cctx, *cctxOrig; + AVCodecContext *cctx, *cctxOrig; int videoStreamIndex; QReadWriteLock streamMutex; std::atomic_bool _isOpen; diff --git a/src/video/corevideosource.cpp b/src/video/corevideosource.cpp index 0e23da85d..8d190ae24 100644 --- a/src/video/corevideosource.cpp +++ b/src/video/corevideosource.cpp @@ -44,8 +44,9 @@ extern "C" { * only CoreAV can push images to it. */ CoreVideoSource::CoreVideoSource() - : subscribers{0}, deleteOnClose{false}, - stopped{false} + : subscribers{0} + , deleteOnClose{false} + , stopped{false} { } @@ -75,24 +76,22 @@ void CoreVideoSource::pushFrame(const vpx_image_t* vpxframe) avframe->height = height; avframe->format = AV_PIX_FMT_YUV420P; - int bufSize = av_image_alloc(avframe->data, avframe->linesize, - width, height, - static_cast(AV_PIX_FMT_YUV420P), VideoFrame::dataAlignment); + int bufSize = + av_image_alloc(avframe->data, avframe->linesize, width, height, + static_cast(AV_PIX_FMT_YUV420P), VideoFrame::dataAlignment); - if(bufSize < 0){ + if (bufSize < 0) { av_frame_free(&avframe); return; } - for (int i = 0; i < 3; ++i) - { + for (int i = 0; i < 3; ++i) { int dstStride = avframe->linesize[i]; int srcStride = vpxframe->stride[i]; int minStride = std::min(dstStride, srcStride); int size = (i == 0) ? height : height / 2; - for (int j = 0; j < size; ++j) - { + for (int j = 0; j < size; ++j) { uint8_t* dst = avframe->data[i] + dstStride * j; uint8_t* src = vpxframe->planes[i] + srcStride * j; memcpy(dst, src, minStride); @@ -113,10 +112,8 @@ bool CoreVideoSource::subscribe() void CoreVideoSource::unsubscribe() { biglock.lock(); - if (--subscribers == 0) - { - if (deleteOnClose) - { + if (--subscribers == 0) { + if (deleteOnClose) { biglock.unlock(); // DANGEROUS: No member access after this point, that's why we manually unlock delete this; diff --git a/src/video/corevideosource.h b/src/video/corevideosource.h index b14a37007..6378cda11 100644 --- a/src/video/corevideosource.h +++ b/src/video/corevideosource.h @@ -21,10 +21,10 @@ #ifndef COREVIDEOSOURCE_H #define COREVIDEOSOURCE_H -#include -#include #include "videosource.h" #include +#include +#include class CoreVideoSource : public VideoSource { @@ -37,7 +37,7 @@ public: private: CoreVideoSource(); - void pushFrame(const vpx_image_t *frame); + void pushFrame(const vpx_image_t* frame); void setDeleteOnClose(bool newstate); void stopSource(); @@ -49,8 +49,8 @@ private: QMutex biglock; std::atomic_bool stopped; -friend class CoreAV; -friend struct ToxFriendCall; + friend class CoreAV; + friend struct ToxFriendCall; }; #endif // COREVIDEOSOURCE_H diff --git a/src/video/genericnetcamview.cpp b/src/video/genericnetcamview.cpp index 67c4a22c6..0ca259e2f 100644 --- a/src/video/genericnetcamview.cpp +++ b/src/video/genericnetcamview.cpp @@ -65,8 +65,7 @@ QSize GenericNetCamView::getSurfaceMinSize() void GenericNetCamView::setShowMessages(bool show, bool notify) { - if (!show) - { + if (!show) { button->setText(tr("Hide Messages")); button->setIcon(QIcon()); return; diff --git a/src/video/groupnetcamview.cpp b/src/video/groupnetcamview.cpp index 932cd717e..5f17e0de0 100644 --- a/src/video/groupnetcamview.cpp +++ b/src/video/groupnetcamview.cpp @@ -18,19 +18,19 @@ */ #include "groupnetcamview.h" -#include "src/widget/tool/croppinglabel.h" -#include "src/video/videosurface.h" -#include "src/persistence/profile.h" #include "src/audio/audio.h" #include "src/core/core.h" -#include "src/nexus.h" -#include "src/friendlist.h" #include "src/friend.h" +#include "src/friendlist.h" +#include "src/nexus.h" +#include "src/persistence/profile.h" +#include "src/video/videosurface.h" +#include "src/widget/tool/croppinglabel.h" #include +#include #include #include #include -#include #include class LabeledVideo : public QFrame @@ -58,7 +58,6 @@ public: ~LabeledVideo() { - } VideoSurface* getVideoSurface() const @@ -94,8 +93,7 @@ protected: private slots: void updateSize() { - if (videoSurface->isExpanding()) - { + if (videoSurface->isExpanding()) { int width = videoSurface->height() * videoSurface->getRatio(); videoSurface->setMinimumWidth(width); videoSurface->setMaximumWidth(width); @@ -123,7 +121,8 @@ GroupNetCamView::GroupNetCamView(int group, QWidget* parent) splitter->setChildrenCollapsible(false); verLayout->insertWidget(0, splitter, 1); splitter->addWidget(videoLabelSurface); - splitter->setStyleSheet("QSplitter { background-color: black; } QSplitter::handle { background-color: black; }"); + splitter->setStyleSheet( + "QSplitter { background-color: black; } QSplitter::handle { background-color: black; }"); QScrollArea* scrollArea = new QScrollArea(); scrollArea->setVerticalScrollBarPolicy(Qt::ScrollBarAlwaysOff); @@ -145,17 +144,16 @@ GroupNetCamView::GroupNetCamView(int group, QWidget* parent) connect(timer, &QTimer::timeout, this, &GroupNetCamView::onUpdateActivePeer); timer->start(); - connect(Core::getInstance(), &Core::selfAvatarChanged, [this](const QPixmap& pixmap) - { + connect(Core::getInstance(), &Core::selfAvatarChanged, [this](const QPixmap& pixmap) { selfVideoSurface->getVideoSurface()->setAvatar(pixmap); setActive(); }); - connect(Core::getInstance(), &Core::usernameSet, [this](const QString& username) - { + connect(Core::getInstance(), &Core::usernameSet, [this](const QString& username) { selfVideoSurface->setText(username); setActive(); }); - connect(Core::getInstance(), &Core::friendAvatarChanged, this, &GroupNetCamView::friendAvatarChanged); + connect(Core::getInstance(), &Core::friendAvatarChanged, this, + &GroupNetCamView::friendAvatarChanged); selfVideoSurface->setText(Core::getInstance()->getUsername()); } @@ -164,13 +162,14 @@ void GroupNetCamView::clearPeers() { QList keys = videoList.keys(); - for (int &i : keys) + for (int& i : keys) removePeer(i); } void GroupNetCamView::addPeer(int peer, const QString& name) { - QPixmap groupAvatar = Nexus::getProfile()->loadAvatar(Core::getInstance()->getGroupPeerPk(group, peer).toString()); + QPixmap groupAvatar = + Nexus::getProfile()->loadAvatar(Core::getInstance()->getGroupPeerPk(group, peer).toString()); LabeledVideo* labeledVideo = new LabeledVideo(groupAvatar, this); labeledVideo->setText(name); horLayout->insertWidget(horLayout->count() - 1, labeledVideo); @@ -185,8 +184,7 @@ void GroupNetCamView::removePeer(int peer) { auto peerVideo = videoList.find(peer); - if (peerVideo != videoList.end()) - { + if (peerVideo != videoList.end()) { LabeledVideo* labeledVideo = peerVideo.value().video; horLayout->removeWidget(labeledVideo); labeledVideo->deleteLater(); @@ -203,8 +201,7 @@ void GroupNetCamView::onUpdateActivePeer() void GroupNetCamView::setActive(int peer) { - if (peer == -1) - { + if (peer == -1) { videoLabelSurface->setText(selfVideoSurface->getText()); activePeer = -1; return; @@ -212,8 +209,7 @@ void GroupNetCamView::setActive(int peer) auto peerVideo = videoList.find(peer); - if (peerVideo != videoList.end()) - { + if (peerVideo != videoList.end()) { // When group video exists: // videoSurface->setSource(peerVideo.value()->getVideoSurface()->source); @@ -222,7 +218,7 @@ void GroupNetCamView::setActive(int peer) if (lastVideo != videoList.end()) lastVideo.value().video->setActive(false); - LabeledVideo *labeledVideo = peerVideo.value().video; + LabeledVideo* labeledVideo = peerVideo.value().video; videoLabelSurface->setText(labeledVideo->getText()); videoLabelSurface->getVideoSurface()->setAvatar(labeledVideo->getVideoSurface()->getAvatar()); labeledVideo->setActive(); @@ -231,18 +227,15 @@ void GroupNetCamView::setActive(int peer) } } -void GroupNetCamView::friendAvatarChanged(int FriendId, const QPixmap &pixmap) +void GroupNetCamView::friendAvatarChanged(int FriendId, const QPixmap& pixmap) { Friend* f = FriendList::findFriend(FriendId); - for (uint32_t i = 0; i < Core::getInstance()->getGroupNumberPeers(group); ++i) - { - if (Core::getInstance()->getGroupPeerPk(group, i) == f->getPublicKey()) - { + for (uint32_t i = 0; i < Core::getInstance()->getGroupNumberPeers(group); ++i) { + if (Core::getInstance()->getGroupPeerPk(group, i) == f->getPublicKey()) { auto peerVideo = videoList.find(i); - if (peerVideo != videoList.end()) - { + if (peerVideo != videoList.end()) { peerVideo.value().video->getVideoSurface()->setAvatar(pixmap); setActive(); } diff --git a/src/video/groupnetcamview.h b/src/video/groupnetcamview.h index 28945da6c..1753ebb22 100644 --- a/src/video/groupnetcamview.h +++ b/src/video/groupnetcamview.h @@ -31,7 +31,7 @@ class GroupNetCamView : public GenericNetCamView public: GroupNetCamView(int group, QWidget* parent = 0); void clearPeers(); - void addPeer(int peer, const QString &name); + void addPeer(int peer, const QString& name); void removePeer(int peer); public slots: diff --git a/src/video/netcamview.cpp b/src/video/netcamview.cpp index 55d0649f4..b61fe31fa 100644 --- a/src/video/netcamview.cpp +++ b/src/video/netcamview.cpp @@ -19,17 +19,17 @@ #include "netcamview.h" #include "camerasource.h" +#include "src/core/core.h" #include "src/friend.h" #include "src/friendlist.h" -#include "src/core/core.h" +#include "src/nexus.h" +#include "src/persistence/profile.h" +#include "src/persistence/settings.h" #include "src/video/videosurface.h" #include "src/widget/tool/movablewidget.h" -#include "src/persistence/settings.h" -#include "src/persistence/profile.h" -#include "src/nexus.h" -#include #include #include +#include NetCamView::NetCamView(int friendId, QWidget* parent) : GenericNetCamView(parent) @@ -57,33 +57,30 @@ NetCamView::NetCamView(int friendId, QWidget* parent) frameLayout->setMargin(0); updateRatio(); - connections += connect(selfVideoSurface, &VideoSurface::ratioChanged, this, &NetCamView::updateRatio); + connections += + connect(selfVideoSurface, &VideoSurface::ratioChanged, this, &NetCamView::updateRatio); - connections += connect(videoSurface, &VideoSurface::boundaryChanged, [this]() - { + connections += connect(videoSurface, &VideoSurface::boundaryChanged, [this]() { QRect boundingRect = videoSurface->getBoundingRect(); updateFrameSize(boundingRect.size()); selfFrame->setBoundary(boundingRect); }); - connections += connect(videoSurface, &VideoSurface::ratioChanged, [this]() - { + connections += connect(videoSurface, &VideoSurface::ratioChanged, [this]() { selfFrame->setMinimumWidth(selfFrame->minimumHeight() * selfVideoSurface->getRatio()); QRect boundingRect = videoSurface->getBoundingRect(); updateFrameSize(boundingRect.size()); selfFrame->resetBoundary(boundingRect); }); - connections += connect(Core::getInstance(), &Core::selfAvatarChanged, [this](const QPixmap& pixmap) - { - selfVideoSurface->setAvatar(pixmap); - }); + connections += connect(Core::getInstance(), &Core::selfAvatarChanged, + [this](const QPixmap& pixmap) { selfVideoSurface->setAvatar(pixmap); }); - connections += connect(Core::getInstance(), &Core::friendAvatarChanged, [this](int FriendId, const QPixmap& pixmap) - { - if (this->friendId == FriendId) - videoSurface->setAvatar(pixmap); - }); + connections += connect(Core::getInstance(), &Core::friendAvatarChanged, + [this](int FriendId, const QPixmap& pixmap) { + if (this->friendId == FriendId) + videoSurface->setAvatar(pixmap); + }); QRect videoSize = Settings::getInstance().getCamVideoRes(); qDebug() << "SIZER" << videoSize; @@ -95,7 +92,7 @@ NetCamView::~NetCamView() disconnect(conn); } -void NetCamView::show(VideoSource *source, const QString &title) +void NetCamView::show(VideoSource* source, const QString& title) { setSource(source); selfVideoSurface->setSource(&CameraSource::getInstance()); @@ -117,17 +114,17 @@ void NetCamView::hide() QWidget::hide(); } -void NetCamView::setSource(VideoSource *s) +void NetCamView::setSource(VideoSource* s) { videoSurface->setSource(s); } -void NetCamView::setTitle(const QString &title) +void NetCamView::setTitle(const QString& title) { setWindowTitle(title); } -void NetCamView::showEvent(QShowEvent *event) +void NetCamView::showEvent(QShowEvent* event) { Q_UNUSED(event); selfFrame->resetBoundary(videoSurface->getBoundingRect()); diff --git a/src/video/netcamview.h b/src/video/netcamview.h index cf204a2e6..dfdf7c397 100644 --- a/src/video/netcamview.h +++ b/src/video/netcamview.h @@ -34,7 +34,7 @@ class NetCamView : public GenericNetCamView Q_OBJECT public: - NetCamView(int friendId, QWidget* parent=0); + NetCamView(int friendId, QWidget* parent = 0); ~NetCamView(); virtual void show(VideoSource* source, const QString& title); diff --git a/src/video/videoframe.cpp b/src/video/videoframe.cpp index 3c88cf140..d6d12c047 100644 --- a/src/video/videoframe.cpp +++ b/src/video/videoframe.cpp @@ -19,7 +19,7 @@ #include "videoframe.h" -extern "C"{ +extern "C" { #include #include } @@ -73,69 +73,65 @@ extern "C"{ */ // Initialize static fields -VideoFrame::AtomicIDType VideoFrame::frameIDs {0}; +VideoFrame::AtomicIDType VideoFrame::frameIDs{0}; -std::unordered_map VideoFrame::mutexMap {}; -std::unordered_map>> VideoFrame::refsMap {}; +std::unordered_map VideoFrame::mutexMap{}; +std::unordered_map>> + VideoFrame::refsMap{}; -QReadWriteLock VideoFrame::refsLock {}; +QReadWriteLock VideoFrame::refsLock{}; /** * @brief Constructs a new instance of a VideoFrame, sourced by a given AVFrame pointer. - * + * * @param sourceID the VideoSource's ID to track the frame under. * @param sourceFrame the source AVFrame pointer to use, must be valid. * @param dimensions the dimensions of the AVFrame, obtained from the AVFrame if not given. * @param pixFmt the pixel format of the AVFrame, obtained from the AVFrame if not given. * @param freeSourceFrame whether to free the source frame buffers or not. */ -VideoFrame::VideoFrame(IDType sourceID, AVFrame* sourceFrame, QRect dimensions, int pixFmt, bool freeSourceFrame) - : frameID(frameIDs++), - sourceID(sourceID), - sourceDimensions(dimensions), - sourceFrameKey(getFrameKey(dimensions.size(), pixFmt, sourceFrame->linesize[0])), - freeSourceFrame(freeSourceFrame) +VideoFrame::VideoFrame(IDType sourceID, AVFrame* sourceFrame, QRect dimensions, int pixFmt, + bool freeSourceFrame) + : frameID(frameIDs++) + , sourceID(sourceID) + , sourceDimensions(dimensions) + , sourceFrameKey(getFrameKey(dimensions.size(), pixFmt, sourceFrame->linesize[0])) + , freeSourceFrame(freeSourceFrame) { // We override the pixel format in the case a deprecated one is used - switch(pixFmt) - { - case AV_PIX_FMT_YUVJ420P: - { + switch (pixFmt) { + case AV_PIX_FMT_YUVJ420P: { sourcePixelFormat = AV_PIX_FMT_YUV420P; sourceFrame->color_range = AVCOL_RANGE_MPEG; break; } - case AV_PIX_FMT_YUVJ411P: - { + case AV_PIX_FMT_YUVJ411P: { sourcePixelFormat = AV_PIX_FMT_YUV411P; sourceFrame->color_range = AVCOL_RANGE_MPEG; break; } - case AV_PIX_FMT_YUVJ422P: - { + case AV_PIX_FMT_YUVJ422P: { sourcePixelFormat = AV_PIX_FMT_YUV422P; sourceFrame->color_range = AVCOL_RANGE_MPEG; break; } - case AV_PIX_FMT_YUVJ444P: - { + case AV_PIX_FMT_YUVJ444P: { sourcePixelFormat = AV_PIX_FMT_YUV444P; sourceFrame->color_range = AVCOL_RANGE_MPEG; break; } - case AV_PIX_FMT_YUVJ440P: - { + case AV_PIX_FMT_YUVJ440P: { sourcePixelFormat = AV_PIX_FMT_YUV440P; sourceFrame->color_range = AVCOL_RANGE_MPEG; break; } - default:{ + default: { sourcePixelFormat = pixFmt; sourceFrame->color_range = AVCOL_RANGE_UNSPECIFIED; } @@ -145,7 +141,10 @@ VideoFrame::VideoFrame(IDType sourceID, AVFrame* sourceFrame, QRect dimensions, } VideoFrame::VideoFrame(IDType sourceID, AVFrame* sourceFrame, bool freeSourceFrame) - : VideoFrame(sourceID, sourceFrame, QRect {0, 0, sourceFrame->width, sourceFrame->height}, sourceFrame->format, freeSourceFrame){} + : VideoFrame(sourceID, sourceFrame, QRect{0, 0, sourceFrame->width, sourceFrame->height}, + sourceFrame->format, freeSourceFrame) +{ +} /** * @brief Destructor for VideoFrame. @@ -162,8 +161,7 @@ VideoFrame::~VideoFrame() // Delete tracked reference refsLock.lockForRead(); - if(refsMap.count(sourceID) > 0) - { + if (refsMap.count(sourceID) > 0) { QMutex& sourceMutex = mutexMap[sourceID]; sourceMutex.lock(); @@ -204,8 +202,7 @@ std::shared_ptr VideoFrame::trackFrame() // Add frame to tracked reference list refsLock.lockForRead(); - if(refsMap.count(sourceID) == 0) - { + if (refsMap.count(sourceID) == 0) { // We need to add a new source to our reference map, obtain write lock refsLock.unlock(); refsLock.lockForWrite(); @@ -215,7 +212,7 @@ std::shared_ptr VideoFrame::trackFrame() sourceMutex.lock(); - std::shared_ptr ret {this}; + std::shared_ptr ret{this}; refsMap[sourceID][frameID] = ret; @@ -240,26 +237,22 @@ void VideoFrame::untrackFrames(const VideoFrame::IDType& sourceID, bool releaseF { refsLock.lockForWrite(); - if(refsMap.count(sourceID) == 0) - { + if (refsMap.count(sourceID) == 0) { // No tracking reference exists for source, simply return refsLock.unlock(); return; } - if(releaseFrames) - { + if (releaseFrames) { QMutex& sourceMutex = mutexMap[sourceID]; sourceMutex.lock(); - for(auto& frameIterator : refsMap[sourceID]) - { + for (auto& frameIterator : refsMap[sourceID]) { std::shared_ptr frame = frameIterator.second.lock(); - if(frame) - { + if (frame) { frame->releaseFrame(); } } @@ -302,14 +295,12 @@ void VideoFrame::releaseFrame() */ const AVFrame* VideoFrame::getAVFrame(QSize frameSize, const int pixelFormat, const bool requireAligned) { - if(!frameSize.isValid()) - { + if (!frameSize.isValid()) { frameSize = sourceDimensions.size(); } // Since we are retrieving the AVFrame* directly, we merely need to pass the arguement through - const std::function converter = [](AVFrame* const frame) - { + const std::function converter = [](AVFrame* const frame) { return frame; }; @@ -333,19 +324,18 @@ const AVFrame* VideoFrame::getAVFrame(QSize frameSize, const int pixelFormat, co */ QImage VideoFrame::toQImage(QSize frameSize) { - if(!frameSize.isValid()) - { + if (!frameSize.isValid()) { frameSize = sourceDimensions.size(); } // Converter function (constructs QImage out of AVFrame*) - const std::function converter = [&](AVFrame* const frame) - { - return QImage {*(frame->data), frameSize.width(), frameSize.height(), *(frame->linesize), QImage::Format_RGB888}; + const std::function converter = [&](AVFrame* const frame) { + return QImage{*(frame->data), frameSize.width(), frameSize.height(), *(frame->linesize), + QImage::Format_RGB888}; }; // Returns an empty constructed QImage in case of invalid generation - return toGenericObject(frameSize, AV_PIX_FMT_RGB24, false, converter, QImage {}); + return toGenericObject(frameSize, AV_PIX_FMT_RGB24, false, converter, QImage{}); } /** @@ -361,25 +351,21 @@ QImage VideoFrame::toQImage(QSize frameSize) */ ToxYUVFrame VideoFrame::toToxYUVFrame(QSize frameSize) { - if(!frameSize.isValid()) - { + if (!frameSize.isValid()) { frameSize = sourceDimensions.size(); } // Converter function (constructs ToxAVFrame out of AVFrame*) - const std::function converter = [&](AVFrame* const frame) - { - ToxYUVFrame ret - { - static_cast(frameSize.width()), - static_cast(frameSize.height()), - frame->data[0], frame->data[1], frame->data[2] - }; + const std::function converter = [&](AVFrame* const frame) { + ToxYUVFrame ret{static_cast(frameSize.width()), + static_cast(frameSize.height()), frame->data[0], + frame->data[1], frame->data[2]}; return ret; }; - return toGenericObject(frameSize, AV_PIX_FMT_YUV420P, true, converter, ToxYUVFrame {0, 0, nullptr, nullptr, nullptr}); + return toGenericObject(frameSize, AV_PIX_FMT_YUV420P, true, converter, + ToxYUVFrame{0, 0, nullptr, nullptr, nullptr}); } /** @@ -433,11 +419,14 @@ int VideoFrame::getSourcePixelFormat() const * @param pixFmt the pixel format of the frame. * @param lineAligned whether the linesize matches the width of the image. */ -VideoFrame::FrameBufferKey::FrameBufferKey(const int pixFmt, const int width, const int height, const bool lineAligned) - : frameWidth(width), - frameHeight(height), - pixelFormat(pixFmt), - linesizeAligned(lineAligned){} +VideoFrame::FrameBufferKey::FrameBufferKey(const int pixFmt, const int width, const int height, + const bool lineAligned) + : frameWidth(width) + , frameHeight(height) + , pixelFormat(pixFmt) + , linesizeAligned(lineAligned) +{ +} /** * @brief Comparison operator for FrameBufferKey. @@ -447,10 +436,8 @@ VideoFrame::FrameBufferKey::FrameBufferKey(const int pixFmt, const int width, co */ bool VideoFrame::FrameBufferKey::operator==(const FrameBufferKey& other) const { - return pixelFormat == other.pixelFormat && - frameWidth == other.frameWidth && - frameHeight == other.frameHeight && - linesizeAligned == other.linesizeAligned; + return pixelFormat == other.pixelFormat && frameWidth == other.frameWidth + && frameHeight == other.frameHeight && linesizeAligned == other.linesizeAligned; } /** @@ -498,7 +485,8 @@ size_t VideoFrame::FrameBufferKey::hash(const FrameBufferKey& key) * @param linesize the maximum linesize of the frame, may be larger than the width. * @return a FrameBufferKey object representing the key for the frameBuffer map. */ -VideoFrame::FrameBufferKey VideoFrame::getFrameKey(const QSize& frameSize, const int pixFmt, const int linesize) +VideoFrame::FrameBufferKey VideoFrame::getFrameKey(const QSize& frameSize, const int pixFmt, + const int linesize) { return getFrameKey(frameSize, pixFmt, frameSize.width() == linesize); } @@ -511,7 +499,8 @@ VideoFrame::FrameBufferKey VideoFrame::getFrameKey(const QSize& frameSize, const * @param frameAligned true if the frame is aligned, false otherwise. * @return a FrameBufferKey object representing the key for the frameBuffer map. */ -VideoFrame::FrameBufferKey VideoFrame::getFrameKey(const QSize& frameSize, const int pixFmt, const bool frameAligned) +VideoFrame::FrameBufferKey VideoFrame::getFrameKey(const QSize& frameSize, const int pixFmt, + const bool frameAligned) { return {frameSize.width(), frameSize.height(), pixFmt, frameAligned}; } @@ -531,30 +520,26 @@ VideoFrame::FrameBufferKey VideoFrame::getFrameKey(const QSize& frameSize, const * @return a pointer to a AVFrame with the given parameters or nullptr if no such frame was * found. */ -AVFrame* VideoFrame::retrieveAVFrame(const QSize& dimensions, const int pixelFormat, const bool requireAligned) +AVFrame* VideoFrame::retrieveAVFrame(const QSize& dimensions, const int pixelFormat, + const bool requireAligned) { - if(!requireAligned) - { + if (!requireAligned) { /* * We attempt to obtain a unaligned frame first because an unaligned linesize corresponds * to a data aligned frame. */ FrameBufferKey frameKey = getFrameKey(dimensions, pixelFormat, false); - if(frameBuffer.count(frameKey) > 0) - { + if (frameBuffer.count(frameKey) > 0) { return frameBuffer[frameKey]; } } FrameBufferKey frameKey = getFrameKey(dimensions, pixelFormat, true); - if(frameBuffer.count(frameKey) > 0) - { + if (frameBuffer.count(frameKey) > 0) { return frameBuffer[frameKey]; - } - else - { + } else { return nullptr; } } @@ -569,11 +554,12 @@ AVFrame* VideoFrame::retrieveAVFrame(const QSize& dimensions, const int pixelFor * @param requireAligned true if the generated frame needs to be frame aligned, false otherwise. * @return an AVFrame with the given specifications. */ -AVFrame* VideoFrame::generateAVFrame(const QSize& dimensions, const int pixelFormat, const bool requireAligned) +AVFrame* VideoFrame::generateAVFrame(const QSize& dimensions, const int pixelFormat, + const bool requireAligned) { AVFrame* ret = av_frame_alloc(); - if(!ret){ + if (!ret) { return nullptr; } @@ -589,21 +575,15 @@ AVFrame* VideoFrame::generateAVFrame(const QSize& dimensions, const int pixelFor int bufSize; - if(!requireAligned || (dimensions.width() % 8 == 0 && dimensions.height() % 8 == 0)) - { - bufSize = av_image_alloc(ret->data, ret->linesize, - dimensions.width(), dimensions.height(), + if (!requireAligned || (dimensions.width() % 8 == 0 && dimensions.height() % 8 == 0)) { + bufSize = av_image_alloc(ret->data, ret->linesize, dimensions.width(), dimensions.height(), static_cast(pixelFormat), dataAlignment); - } - else - { - bufSize = av_image_alloc(ret->data, ret->linesize, - dimensions.width(), dimensions.height(), + } else { + bufSize = av_image_alloc(ret->data, ret->linesize, dimensions.width(), dimensions.height(), static_cast(pixelFormat), 1); } - if(bufSize < 0) - { + if (bufSize < 0) { av_frame_free(&ret); return nullptr; } @@ -611,13 +591,13 @@ AVFrame* VideoFrame::generateAVFrame(const QSize& dimensions, const int pixelFor // Bilinear is better for shrinking, bicubic better for upscaling int resizeAlgo = sourceDimensions.width() > dimensions.width() ? SWS_BILINEAR : SWS_BICUBIC; - SwsContext* swsCtx = sws_getContext(sourceDimensions.width(), sourceDimensions.height(), - static_cast(sourcePixelFormat), - dimensions.width(), dimensions.height(), - static_cast(pixelFormat), - resizeAlgo, nullptr, nullptr, nullptr); + SwsContext* swsCtx = + sws_getContext(sourceDimensions.width(), sourceDimensions.height(), + static_cast(sourcePixelFormat), dimensions.width(), + dimensions.height(), static_cast(pixelFormat), resizeAlgo, + nullptr, nullptr, nullptr); - if(!swsCtx){ + if (!swsCtx) { av_freep(&ret->data[0]); av_frame_unref(ret); av_frame_free(&ret); @@ -626,7 +606,8 @@ AVFrame* VideoFrame::generateAVFrame(const QSize& dimensions, const int pixelFor AVFrame* source = frameBuffer[sourceFrameKey]; - sws_scale(swsCtx, source->data, source->linesize, 0, sourceDimensions.height(), ret->data, ret->linesize); + sws_scale(swsCtx, source->data, source->linesize, 0, sourceDimensions.height(), ret->data, + ret->linesize); sws_freeContext(swsCtx); return ret; @@ -659,8 +640,7 @@ AVFrame* VideoFrame::storeAVFrame(AVFrame* frame, const QSize& dimensions, const FrameBufferKey frameKey = getFrameKey(dimensions, pixelFormat, frame->linesize[0]); // We check the prescence of the frame in case of double-computation - if(frameBuffer.count(frameKey) > 0) - { + if (frameBuffer.count(frameKey) > 0) { AVFrame* old_ret = frameBuffer[frameKey]; // Free new frame @@ -669,9 +649,7 @@ AVFrame* VideoFrame::storeAVFrame(AVFrame* frame, const QSize& dimensions, const av_frame_free(&frame); return old_ret; - } - else - { + } else { frameBuffer[frameKey] = frame; return frame; @@ -686,26 +664,21 @@ AVFrame* VideoFrame::storeAVFrame(AVFrame* frame, const QSize& dimensions, const void VideoFrame::deleteFrameBuffer() { // An empty framebuffer represents a frame that's already been freed - if(frameBuffer.empty()){ + if (frameBuffer.empty()) { return; } - for(const auto& frameIterator : frameBuffer) - { + for (const auto& frameIterator : frameBuffer) { AVFrame* frame = frameIterator.second; // Treat source frame and derived frames separately - if(sourceFrameKey == frameIterator.first) - { - if(freeSourceFrame) - { + if (sourceFrameKey == frameIterator.first) { + if (freeSourceFrame) { av_freep(&frame->data[0]); } av_frame_unref(frame); av_frame_free(&frame); - } - else - { + } else { av_freep(&frame->data[0]); av_frame_unref(frame); av_frame_free(&frame); @@ -737,21 +710,20 @@ void VideoFrame::deleteFrameBuffer() */ template T VideoFrame::toGenericObject(const QSize& dimensions, const int pixelFormat, const bool requireAligned, - const std::function objectConstructor, const T& nullObject) + const std::function objectConstructor, + const T& nullObject) { frameLock.lockForRead(); // We return nullObject if the VideoFrame is no longer valid - if(frameBuffer.size() == 0) - { + if (frameBuffer.size() == 0) { frameLock.unlock(); return nullObject; } AVFrame* frame = retrieveAVFrame(dimensions, static_cast(pixelFormat), requireAligned); - if(frame) - { + if (frame) { T ret = objectConstructor(frame); frameLock.unlock(); @@ -780,10 +752,12 @@ T VideoFrame::toGenericObject(const QSize& dimensions, const int pixelFormat, co } // Explicitly specialize VideoFrame::toGenericObject() function -template QImage VideoFrame::toGenericObject(const QSize& dimensions, const int pixelFormat, const bool requireAligned, - const std::function objectConstructor, const QImage& nullObject); -template ToxYUVFrame VideoFrame::toGenericObject(const QSize& dimensions, const int pixelFormat, const bool requireAligned, -const std::function objectConstructor, const ToxYUVFrame& nullObject); +template QImage VideoFrame::toGenericObject( + const QSize& dimensions, const int pixelFormat, const bool requireAligned, + const std::function objectConstructor, const QImage& nullObject); +template ToxYUVFrame VideoFrame::toGenericObject( + const QSize& dimensions, const int pixelFormat, const bool requireAligned, + const std::function objectConstructor, const ToxYUVFrame& nullObject); /** * @brief Returns whether the given ToxYUVFrame represents a valid frame or not. diff --git a/src/video/videoframe.h b/src/video/videoframe.h index 10d74c09f..83203c343 100644 --- a/src/video/videoframe.h +++ b/src/video/videoframe.h @@ -26,7 +26,7 @@ #include #include -extern "C"{ +extern "C" { #include } @@ -58,12 +58,14 @@ public: using AtomicIDType = std::atomic_uint_fast64_t; public: - VideoFrame(IDType sourceID, AVFrame* sourceFrame, QRect dimensions, int pixFmt, bool freeSourceFrame = false); + VideoFrame(IDType sourceID, AVFrame* sourceFrame, QRect dimensions, int pixFmt, + bool freeSourceFrame = false); VideoFrame(IDType sourceID, AVFrame* sourceFrame, bool freeSourceFrame = false); ~VideoFrame(); - // Copy/Move operations are disabled for the VideoFrame, encapsulate with a std::shared_ptr to manage. + // Copy/Move operations are disabled for the VideoFrame, encapsulate with a std::shared_ptr to + // manage. VideoFrame(const VideoFrame& other) = delete; VideoFrame(VideoFrame&& other) = delete; @@ -90,7 +92,8 @@ public: static constexpr int dataAlignment = 32; private: - class FrameBufferKey{ + class FrameBufferKey + { public: FrameBufferKey(const int width, const int height, const int pixFmt, const bool lineAligned); @@ -119,7 +122,8 @@ private: private: static FrameBufferKey getFrameKey(const QSize& frameSize, const int pixFmt, const int linesize); - static FrameBufferKey getFrameKey(const QSize& frameSize, const int pixFmt, const bool frameAligned); + static FrameBufferKey getFrameKey(const QSize& frameSize, const int pixFmt, + const bool frameAligned); AVFrame* retrieveAVFrame(const QSize& dimensions, const int pixelFormat, const bool requireAligned); AVFrame* generateAVFrame(const QSize& dimensions, const int pixelFormat, const bool requireAligned); @@ -137,7 +141,8 @@ private: const IDType sourceID; // Main framebuffer store - std::unordered_map> frameBuffer {3, FrameBufferKey::hash}; + std::unordered_map> + frameBuffer{3, FrameBufferKey::hash}; // Source frame const QRect sourceDimensions; @@ -152,7 +157,7 @@ private: static std::unordered_map>> refsMap; // Concurrency - QReadWriteLock frameLock {}; + QReadWriteLock frameLock{}; static QReadWriteLock refsLock; }; diff --git a/src/video/videomode.cpp b/src/video/videomode.cpp index 0fc1ecabc..111e952c9 100644 --- a/src/video/videomode.cpp +++ b/src/video/videomode.cpp @@ -33,16 +33,23 @@ * @brief Frames per second supported by the device at this resolution */ -VideoMode::VideoMode(int width, int height, int x, int y, int FPS, int format) : - width(width), height(height), x(x), y(y), - FPS(FPS), pixel_format(format) +VideoMode::VideoMode(int width, int height, int x, int y, int FPS, int format) + : width(width) + , height(height) + , x(x) + , y(y) + , FPS(FPS) + , pixel_format(format) { } -VideoMode::VideoMode(QRect rect) : - width(rect.width()), height(rect.height()), - x(rect.x()), y(rect.y()), - FPS(0), pixel_format(0) +VideoMode::VideoMode(QRect rect) + : width(rect.width()) + , height(rect.height()) + , x(rect.x()) + , y(rect.y()) + , FPS(0) + , pixel_format(0) { } @@ -51,19 +58,15 @@ QRect VideoMode::toRect() const return QRect(x, y, width, height); } -bool VideoMode::operator==(const VideoMode &other) const +bool VideoMode::operator==(const VideoMode& other) const { - return width == other.width - && height == other.height - && x == other.x - && y == other.y - && FPS == other.FPS - && pixel_format == other.pixel_format; + return width == other.width && height == other.height && x == other.x && y == other.y + && FPS == other.FPS && pixel_format == other.pixel_format; } -uint32_t VideoMode::norm(const VideoMode &other) const +uint32_t VideoMode::norm(const VideoMode& other) const { - return qAbs(this->width-other.width) + qAbs(this->height-other.height); + return qAbs(this->width - other.width) + qAbs(this->height - other.height); } /** diff --git a/src/video/videomode.h b/src/video/videomode.h index 6aabadc47..ffb22d924 100644 --- a/src/video/videomode.h +++ b/src/video/videomode.h @@ -30,8 +30,7 @@ struct VideoMode float FPS; uint32_t pixel_format; - VideoMode(int width = 0, int height = 0, int x = 0, int y = 0, - int FPS = 0, int format = 0); + VideoMode(int width = 0, int height = 0, int x = 0, int y = 0, int FPS = 0, int format = 0); VideoMode(QRect rect); @@ -43,4 +42,3 @@ struct VideoMode }; #endif // VIDEOMODE_H - diff --git a/src/video/videosource.cpp b/src/video/videosource.cpp index a9769c7df..bc50bfb73 100644 --- a/src/video/videosource.cpp +++ b/src/video/videosource.cpp @@ -28,4 +28,4 @@ */ // Initialize sourceIDs to 0 -VideoSource::AtomicIDType VideoSource::sourceIDs {0}; +VideoSource::AtomicIDType VideoSource::sourceIDs{0}; diff --git a/src/video/videosource.h b/src/video/videosource.h index 0b270ba2a..8e1d1ff00 100644 --- a/src/video/videosource.h +++ b/src/video/videosource.h @@ -37,11 +37,15 @@ public: using AtomicIDType = std::atomic_uint_fast64_t; public: - VideoSource() : id(sourceIDs++){} + VideoSource() + : id(sourceIDs++) + { + } virtual ~VideoSource() = default; /** - * @brief If subscribe sucessfully opens the source, it will start emitting frameAvailable signals. + * @brief If subscribe sucessfully opens the source, it will start emitting frameAvailable + * signals. */ virtual bool subscribe() = 0; /** @@ -62,6 +66,7 @@ signals: * sending frames again later */ void sourceStopped(); + private: // Used to manage a global ID for all VideoSources static AtomicIDType sourceIDs; diff --git a/src/video/videosurface.cpp b/src/video/videosurface.cpp index c9cac82a2..916901da2 100644 --- a/src/video/videosurface.cpp +++ b/src/video/videosurface.cpp @@ -18,17 +18,17 @@ */ #include "videosurface.h" -#include "src/video/videoframe.h" +#include "src/core/core.h" #include "src/friend.h" #include "src/friendlist.h" -#include "src/widget/friendwidget.h" #include "src/persistence/settings.h" -#include "src/core/core.h" +#include "src/video/videoframe.h" +#include "src/widget/friendwidget.h" #include "src/widget/style.h" -#include -#include #include +#include +#include /** * @var std::atomic_bool VideoSurface::frameLock @@ -52,7 +52,7 @@ VideoSurface::VideoSurface(const QPixmap& avatar, QWidget* parent, bool expandin recalulateBounds(); } -VideoSurface::VideoSurface(const QPixmap& avatar, VideoSource *source, QWidget* parent) +VideoSurface::VideoSurface(const QPixmap& avatar, VideoSource* source, QWidget* parent) : VideoSurface(avatar, parent) { setSource(source); @@ -75,7 +75,7 @@ bool VideoSurface::isExpanding() const * * Unsubscribe from old source and subscribe to new. */ -void VideoSurface::setSource(VideoSource *src) +void VideoSurface::setSource(VideoSource* src) { if (source == src) return; @@ -97,7 +97,7 @@ float VideoSurface::getRatio() const return ratio; } -void VideoSurface::setAvatar(const QPixmap &pixmap) +void VideoSurface::setAvatar(const QPixmap& pixmap) { avatar = pixmap; update(); @@ -110,8 +110,7 @@ QPixmap VideoSurface::getAvatar() const void VideoSurface::subscribe() { - if (source && hasSubscribed++ == 0) - { + if (source && hasSubscribed++ == 0) { source->subscribe(); connect(source, &VideoSource::frameAvailable, this, &VideoSurface::onNewFrameAvailable); connect(source, &VideoSource::sourceStopped, this, &VideoSurface::onSourceStopped); @@ -151,8 +150,7 @@ void VideoSurface::onNewFrameAvailable(std::shared_ptr newFrame) float newRatio = getSizeRatio(newSize); - if (newRatio != ratio && isVisible()) - { + if (newRatio != ratio && isVisible()) { ratio = newRatio; recalulateBounds(); emit ratioChanged(); @@ -175,20 +173,18 @@ void VideoSurface::paintEvent(QPaintEvent*) QPainter painter(this); painter.fillRect(painter.viewport(), Qt::black); - if (lastFrame) - { + if (lastFrame) { QImage frame = lastFrame->toQImage(rect().size()); if (frame.isNull()) lastFrame.reset(); painter.drawImage(boundingRect, frame, frame.rect(), Qt::NoFormatConversion); - } - else - { + } else { painter.fillRect(boundingRect, Qt::white); QPixmap drawnAvatar = avatar; if (drawnAvatar.isNull()) - drawnAvatar = Style::scaleSvgImage(":/img/contact_dark.svg", boundingRect.width(), boundingRect.height()); + drawnAvatar = Style::scaleSvgImage(":/img/contact_dark.svg", boundingRect.width(), + boundingRect.height()); painter.drawPixmap(boundingRect, drawnAvatar, drawnAvatar.rect()); } @@ -206,17 +202,14 @@ void VideoSurface::resizeEvent(QResizeEvent* event) void VideoSurface::showEvent(QShowEvent* e) { Q_UNUSED(e); - //emit ratioChanged(); + // emit ratioChanged(); } void VideoSurface::recalulateBounds() { - if (expanding) - { + if (expanding) { boundingRect = contentsRect(); - } - else - { + } else { QPoint pos; QSize size; QSize usableSize = contentsRect().size(); diff --git a/src/video/videosurface.h b/src/video/videosurface.h index 5dcce94ef..845c581a8 100644 --- a/src/video/videosurface.h +++ b/src/video/videosurface.h @@ -20,10 +20,10 @@ #ifndef SELFCAMVIEW_H #define SELFCAMVIEW_H -#include -#include -#include #include "src/video/videosource.h" +#include +#include +#include class VideoSurface : public QWidget { diff --git a/src/widget/about/aboutuser.cpp b/src/widget/about/aboutuser.cpp index 6556ef0f7..8a71cd444 100644 --- a/src/widget/about/aboutuser.cpp +++ b/src/widget/about/aboutuser.cpp @@ -1,16 +1,16 @@ #include "aboutuser.h" #include "ui_aboutuser.h" -#include "src/persistence/settings.h" -#include "src/persistence/profile.h" #include "src/nexus.h" +#include "src/persistence/profile.h" +#include "src/persistence/settings.h" #include #include #include -AboutUser::AboutUser(ToxPk &toxId, QWidget* parent) : - QDialog(parent), - ui(new Ui::AboutUser) +AboutUser::AboutUser(ToxPk& toxId, QWidget* parent) + : QDialog(parent) + , ui(new Ui::AboutUser) { ui->setupUi(this); ui->label_4->hide(); @@ -19,7 +19,7 @@ AboutUser::AboutUser(ToxPk &toxId, QWidget* parent) : connect(ui->buttonBox, &QDialogButtonBox::accepted, this, &AboutUser::onAcceptedClicked); connect(ui->autoacceptfile, &QCheckBox::clicked, this, &AboutUser::onAutoAcceptDirClicked); connect(ui->autoacceptcall, SIGNAL(activated(int)), this, SLOT(onAutoAcceptCallClicked(void))); - connect(ui->selectSaveDir, &QPushButton::clicked, this, &AboutUser::onSelectDirClicked); + connect(ui->selectSaveDir, &QPushButton::clicked, this, &AboutUser::onSelectDirClicked); connect(ui->removeHistory, &QPushButton::clicked, this, &AboutUser::onRemoveHistoryClicked); this->friendPk = toxId; @@ -30,7 +30,7 @@ AboutUser::AboutUser(ToxPk &toxId, QWidget* parent) : ui->selectSaveDir->setEnabled(ui->autoacceptfile->isChecked()); - if(ui->autoacceptfile->isChecked()) + if (ui->autoacceptfile->isChecked()) ui->selectSaveDir->setText(Settings::getInstance().getAutoAcceptDir(this->friendPk)); } @@ -39,37 +39,31 @@ void AboutUser::setFriend(Friend* f) this->setWindowTitle(f->getDisplayedName()); ui->userName->setText(f->getDisplayedName()); ui->publicKey->setText(QString(f->getPublicKey().toString())); - ui->publicKey->setCursorPosition(0); //scroll textline to left + ui->publicKey->setCursorPosition(0); // scroll textline to left ui->note->setPlainText(Settings::getInstance().getContactNote(f->getPublicKey())); QPixmap avatar = Nexus::getProfile()->loadAvatar(f->getPublicKey().toString()); ui->statusMessage->setText(f->getStatusMessage()); - if(!avatar.isNull()) { + if (!avatar.isNull()) { ui->avatar->setPixmap(avatar); } else { ui->avatar->setPixmap(QPixmap(":/img/contact_dark.svg")); } - } void AboutUser::onAutoAcceptDirClicked() { QString dir; - if (!ui->autoacceptfile->isChecked()) - { + if (!ui->autoacceptfile->isChecked()) { dir = QDir::homePath(); ui->autoacceptfile->setChecked(false); Settings::getInstance().setAutoAcceptDir(this->friendPk, ""); ui->selectSaveDir->setText(tr("Auto accept for this contact is disabled")); - } - else if (ui->autoacceptfile->isChecked()) - { - dir = QFileDialog::getExistingDirectory(this, - tr("Choose an auto accept directory", "popup title"), - dir, - QFileDialog::DontUseNativeDialog); - if(dir.isEmpty()) - { + } else if (ui->autoacceptfile->isChecked()) { + dir = QFileDialog::getExistingDirectory(this, tr("Choose an auto accept directory", + "popup title"), + dir, QFileDialog::DontUseNativeDialog); + if (dir.isEmpty()) { ui->autoacceptfile->setChecked(false); return; // user canellced } @@ -82,7 +76,9 @@ void AboutUser::onAutoAcceptDirClicked() void AboutUser::onAutoAcceptCallClicked() { - Settings::getInstance().setAutoAcceptCall(this->friendPk,Settings::AutoAcceptCallFlags(QFlag(ui->autoacceptcall->currentIndex()))); + Settings::getInstance().setAutoAcceptCall(this->friendPk, + Settings::AutoAcceptCallFlags( + QFlag(ui->autoacceptcall->currentIndex()))); Settings::getInstance().savePersonal(); } @@ -91,8 +87,7 @@ void AboutUser::onSelectDirClicked() QString dir; dir = QFileDialog::getExistingDirectory(this, tr("Choose an auto accept directory", "popup title"), - dir, - QFileDialog::DontUseNativeDialog); + dir, QFileDialog::DontUseNativeDialog); ui->autoacceptfile->setChecked(true); Settings::getInstance().setAutoAcceptDir(this->friendPk, dir); Settings::getInstance().savePersonal(); @@ -112,10 +107,9 @@ void AboutUser::onRemoveHistoryClicked() History* history = Nexus::getProfile()->getHistory(); if (history) history->removeFriendHistory(friendPk.toString()); - QMessageBox::information(this, - tr("History removed"), - tr("Chat history with %1 removed!").arg(ui->userName->text().toHtmlEscaped()), - QMessageBox::Ok); + QMessageBox::information(this, tr("History removed"), + tr("Chat history with %1 removed!").arg(ui->userName->text().toHtmlEscaped()), + QMessageBox::Ok); } AboutUser::~AboutUser() diff --git a/src/widget/about/aboutuser.h b/src/widget/about/aboutuser.h index cb97c9a03..5a8cdf253 100644 --- a/src/widget/about/aboutuser.h +++ b/src/widget/about/aboutuser.h @@ -1,8 +1,8 @@ #ifndef ABOUTUSER_H #define ABOUTUSER_H -#include #include "src/friend.h" +#include namespace Ui { @@ -14,12 +14,12 @@ class AboutUser : public QDialog Q_OBJECT public: - explicit AboutUser(ToxPk &toxID, QWidget* parent = 0); + explicit AboutUser(ToxPk& toxID, QWidget* parent = 0); ~AboutUser(); void setFriend(Friend* f); private: - Ui::AboutUser *ui; + Ui::AboutUser* ui; ToxPk friendPk; private slots: diff --git a/src/widget/categorywidget.cpp b/src/widget/categorywidget.cpp index c2d9352a0..a506e6cfe 100644 --- a/src/widget/categorywidget.cpp +++ b/src/widget/categorywidget.cpp @@ -30,7 +30,8 @@ void CategoryWidget::emitChatroomWidget(QLayout* layout, int index) { - GenericChatroomWidget* chatWidget = qobject_cast(layout->itemAt(index)->widget()); + GenericChatroomWidget* chatWidget = + qobject_cast(layout->itemAt(index)->widget()); if (chatWidget != nullptr) emit chatWidget->chatroomWidgetClicked(chatWidget); } @@ -99,12 +100,12 @@ void CategoryWidget::setExpanded(bool isExpanded, bool save) onExpand(); } -void CategoryWidget::leaveEvent(QEvent *event) +void CategoryWidget::leaveEvent(QEvent* event) { event->ignore(); } -void CategoryWidget::setName(const QString &name, bool save) +void CategoryWidget::setName(const QString& name, bool save) { nameLabel->setText(name); @@ -148,10 +149,10 @@ bool CategoryWidget::hasChatrooms() const return listLayout->hasChatrooms(); } -void CategoryWidget::search(const QString &searchString, bool updateAll, bool hideOnline, bool hideOffline) +void CategoryWidget::search(const QString& searchString, bool updateAll, bool hideOnline, + bool hideOffline) { - if (updateAll) - { + if (updateAll) { listLayout->searchChatrooms(searchString, hideOnline, hideOffline); } bool inCategory = searchString.isEmpty() && !(hideOnline && hideOffline); @@ -160,37 +161,29 @@ void CategoryWidget::search(const QString &searchString, bool updateAll, bool hi bool CategoryWidget::cycleContacts(bool forward) { - if (listLayout->friendTotalCount() == 0) - { + if (listLayout->friendTotalCount() == 0) { return false; } - if (forward) - { - if (!listLayout->getLayoutOnline()->isEmpty()) - { + if (forward) { + if (!listLayout->getLayoutOnline()->isEmpty()) { setExpanded(true); emitChatroomWidget(listLayout->getLayoutOnline(), 0); return true; - } - else if (!listLayout->getLayoutOffline()->isEmpty()) - { + } else if (!listLayout->getLayoutOffline()->isEmpty()) { setExpanded(true); emitChatroomWidget(listLayout->getLayoutOffline(), 0); return true; } - } - else - { - if (!listLayout->getLayoutOffline()->isEmpty()) - { + } else { + if (!listLayout->getLayoutOffline()->isEmpty()) { setExpanded(true); - emitChatroomWidget(listLayout->getLayoutOffline(), listLayout->getLayoutOffline()->count() - 1); + emitChatroomWidget(listLayout->getLayoutOffline(), + listLayout->getLayoutOffline()->count() - 1); return true; - } - else if (!listLayout->getLayoutOnline()->isEmpty()) - { + } else if (!listLayout->getLayoutOnline()->isEmpty()) { setExpanded(true); - emitChatroomWidget(listLayout->getLayoutOnline(), listLayout->getLayoutOnline()->count() - 1); + emitChatroomWidget(listLayout->getLayoutOnline(), + listLayout->getLayoutOnline()->count() - 1); return true; } } @@ -208,18 +201,15 @@ bool CategoryWidget::cycleContacts(FriendWidget* activeChatroomWidget, bool forw currentLayout = listLayout->getLayoutOnline(); index = listLayout->indexOfFriendWidget(friendWidget, true); - if (index == -1) - { + if (index == -1) { currentLayout = listLayout->getLayoutOffline(); index = listLayout->indexOfFriendWidget(friendWidget, false); } index += forward ? 1 : -1; - for (;;) - { + for (;;) { // Bounds checking. - if (index < 0) - { + if (index < 0) { if (currentLayout == listLayout->getLayoutOffline()) currentLayout = listLayout->getLayoutOnline(); else @@ -227,9 +217,7 @@ bool CategoryWidget::cycleContacts(FriendWidget* activeChatroomWidget, bool forw index = currentLayout->count() - 1; continue; - } - else if (index >= currentLayout->count()) - { + } else if (index >= currentLayout->count()) { if (currentLayout == listLayout->getLayoutOnline()) currentLayout = listLayout->getLayoutOffline(); else @@ -239,7 +227,8 @@ bool CategoryWidget::cycleContacts(FriendWidget* activeChatroomWidget, bool forw continue; } - GenericChatroomWidget* chatWidget = qobject_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/categorywidget.h b/src/widget/categorywidget.h index 260fa2c55..21b969a90 100644 --- a/src/widget/categorywidget.h +++ b/src/widget/categorywidget.h @@ -37,7 +37,7 @@ public: bool isExpanded() const; void setExpanded(bool isExpanded, bool save = true); - void setName(const QString &name, bool save = true); + void setName(const QString& name, bool save = true); void addFriendWidget(FriendWidget* w, Status s); void removeFriendWidget(FriendWidget* w, Status s); @@ -46,8 +46,8 @@ public: bool hasChatrooms() const; bool cycleContacts(bool forward); bool cycleContacts(FriendWidget* activeChatroomWidget, bool forward); - void search(const QString &searchString, bool updateAll = false, - bool hideOnline = false, bool hideOffline = false); + void search(const QString& searchString, bool updateAll = false, bool hideOnline = false, + bool hideOffline = false); public slots: void onCompactChanged(bool compact); @@ -64,9 +64,15 @@ protected: void emitChatroomWidget(QLayout* layout, int index); private: - virtual void onSetName() {} - virtual void onExpand() {} - virtual void onAddFriendWidget(FriendWidget*) {} + virtual void onSetName() + { + } + virtual void onExpand() + { + } + virtual void onAddFriendWidget(FriendWidget*) + { + } QWidget* listWidget; FriendListLayout* listLayout; diff --git a/src/widget/circlewidget.cpp b/src/widget/circlewidget.cpp index 221f83a71..66f456d49 100644 --- a/src/widget/circlewidget.cpp +++ b/src/widget/circlewidget.cpp @@ -17,21 +17,21 @@ along with qTox. If not, see . */ -#include #include -#include #include -#include #include +#include +#include +#include #include #include "circlewidget.h" #include "contentdialog.h" -#include "friendwidget.h" #include "friendlistwidget.h" -#include "tool/croppinglabel.h" +#include "friendwidget.h" #include "widget.h" +#include "tool/croppinglabel.h" #include "src/friend.h" #include "src/friendlist.h" @@ -46,14 +46,12 @@ CircleWidget::CircleWidget(FriendListWidget* parent, int id) setName(Settings::getInstance().getCircleName(id), false); circleList[id] = this; - connect(nameLabel, &CroppingLabel::editFinished, [this](const QString &newName) - { + connect(nameLabel, &CroppingLabel::editFinished, [this](const QString& newName) { if (!newName.isEmpty()) emit renameRequested(this, newName); }); - connect(nameLabel, &CroppingLabel::editRemoved, [this]() - { + connect(nameLabel, &CroppingLabel::editRemoved, [this]() { if (isCompact()) nameLabel->minimizeMaximumWidth(); }); @@ -95,14 +93,10 @@ void CircleWidget::contextMenuEvent(QContextMenuEvent* event) QAction* selectedItem = menu.exec(mapToGlobal(event->pos())); - if (selectedItem) - { - if (selectedItem == renameAction) - { + if (selectedItem) { + if (selectedItem == renameAction) { editName(); - } - else if (selectedItem == removeAction) - { + } else if (selectedItem == removeAction) { FriendListWidget* friendList = static_cast(parentWidget()); moveFriendWidgets(friendList); @@ -117,27 +111,23 @@ void CircleWidget::contextMenuEvent(QContextMenuEvent* event) assert(true); // This should never happen. circleList.remove(replacedCircle); - } - else if (selectedItem == openAction) - { + } else if (selectedItem == openAction) { ContentDialog* dialog = Widget::getInstance()->createContentDialog(); - for (int i = 0; i < friendOnlineLayout()->count(); ++i) - { - FriendWidget* friendWidget = qobject_cast(friendOnlineLayout()->itemAt(i)->widget()); + for (int i = 0; i < friendOnlineLayout()->count(); ++i) { + FriendWidget* friendWidget = + qobject_cast(friendOnlineLayout()->itemAt(i)->widget()); - if (friendWidget != nullptr) - { + if (friendWidget != nullptr) { Friend* f = friendWidget->getFriend(); dialog->addFriend(friendWidget->friendId, f->getDisplayedName()); } } - for (int i = 0; i < friendOfflineLayout()->count(); ++i) - { - FriendWidget* friendWidget = qobject_cast(friendOfflineLayout()->itemAt(i)->widget()); + for (int i = 0; i < friendOfflineLayout()->count(); ++i) { + FriendWidget* friendWidget = + qobject_cast(friendOfflineLayout()->itemAt(i)->widget()); - if (friendWidget != nullptr) - { + if (friendWidget != nullptr) { Friend* f = friendWidget->getFriend(); dialog->addFriend(friendWidget->friendId, f->getDisplayedName()); } @@ -161,7 +151,7 @@ void CircleWidget::dragEnterEvent(QDragEnterEvent* event) setContainerAttribute(Qt::WA_UnderMouse, true); // Simulate hover. } -void CircleWidget::dragLeaveEvent(QDragLeaveEvent* ) +void CircleWidget::dragLeaveEvent(QDragLeaveEvent*) { setContainerAttribute(Qt::WA_UnderMouse, false); } @@ -171,8 +161,8 @@ void CircleWidget::dropEvent(QDropEvent* event) setExpanded(true, false); // Check, that the element is dropped from qTox - QObject *o = event->source(); - FriendWidget *widget = qobject_cast(o); + QObject* o = event->source(); + FriendWidget* widget = qobject_cast(o); if (!widget) return; @@ -189,8 +179,7 @@ void CircleWidget::dropEvent(QDropEvent* event) addFriendWidget(widget, f->getStatus()); Settings::getInstance().savePersonal(); - if (circleWidget != nullptr) - { + if (circleWidget != nullptr) { circleWidget->updateStatus(); Widget::getInstance()->searchCircle(circleWidget); } @@ -227,18 +216,20 @@ void CircleWidget::updateID(int index) id = index; circleList[id] = this; - for (int i = 0; i < friendOnlineLayout()->count(); ++i) - { - FriendWidget* friendWidget = qobject_cast(friendOnlineLayout()->itemAt(i)->widget()); + for (int i = 0; i < friendOnlineLayout()->count(); ++i) { + FriendWidget* friendWidget = + qobject_cast(friendOnlineLayout()->itemAt(i)->widget()); if (friendWidget != nullptr) - Settings::getInstance().setFriendCircleID(FriendList::findFriend(friendWidget->friendId)->getPublicKey(), id); + Settings::getInstance() + .setFriendCircleID(FriendList::findFriend(friendWidget->friendId)->getPublicKey(), id); } - for (int i = 0; i < friendOfflineLayout()->count(); ++i) - { - FriendWidget* friendWidget = qobject_cast(friendOfflineLayout()->itemAt(i)->widget()); + for (int i = 0; i < friendOfflineLayout()->count(); ++i) { + FriendWidget* friendWidget = + qobject_cast(friendOfflineLayout()->itemAt(i)->widget()); if (friendWidget != nullptr) - Settings::getInstance().setFriendCircleID(FriendList::findFriend(friendWidget->friendId)->getPublicKey(), id); + Settings::getInstance() + .setFriendCircleID(FriendList::findFriend(friendWidget->friendId)->getPublicKey(), id); } } diff --git a/src/widget/circlewidget.h b/src/widget/circlewidget.h index 894c86036..0d9f77d4a 100644 --- a/src/widget/circlewidget.h +++ b/src/widget/circlewidget.h @@ -33,7 +33,7 @@ public: static CircleWidget* getFromID(int id); signals: - void renameRequested(CircleWidget* circleWidget, const QString &newName); + void renameRequested(CircleWidget* circleWidget, const QString& newName); protected: void contextMenuEvent(QContextMenuEvent* event) final override; diff --git a/src/widget/contentdialog.cpp b/src/widget/contentdialog.cpp index 94855fc7a..72f4de3f4 100644 --- a/src/widget/contentdialog.cpp +++ b/src/widget/contentdialog.cpp @@ -32,17 +32,17 @@ #include "groupwidget.h" #include "style.h" #include "widget.h" -#include "tool/adjustingscrollarea.h" -#include "src/persistence/settings.h" +#include "src/core/core.h" #include "src/friend.h" #include "src/friendlist.h" #include "src/group.h" #include "src/grouplist.h" +#include "src/persistence/settings.h" #include "src/widget/form/chatform.h" -#include "src/core/core.h" -#include "src/widget/friendlistlayout.h" #include "src/widget/form/settingswidget.h" +#include "src/widget/friendlistlayout.h" #include "src/widget/translator.h" +#include "tool/adjustingscrollarea.h" ContentDialog* ContentDialog::currentDialog = nullptr; QHash> ContentDialog::friendList; @@ -74,7 +74,7 @@ ContentDialog::ContentDialog(SettingsWidget* settingsWidget, QWidget* parent) onGroupchatPositionChanged(Settings::getInstance().getGroupchatPosition()); - QScrollArea *friendScroll = new QScrollArea(this); + QScrollArea* friendScroll = new QScrollArea(this); friendScroll->setMinimumWidth(220); friendScroll->setFrameStyle(QFrame::NoFrame); friendScroll->setLayoutDirection(Qt::RightToLeft); @@ -135,10 +135,8 @@ ContentDialog::~ContentDialog() auto friendIt = friendList.begin(); - while (friendIt != friendList.end()) - { - if (std::get<0>(friendIt.value()) == this) - { + while (friendIt != friendList.end()) { + if (std::get<0>(friendIt.value()) == this) { friendIt = friendList.erase(friendIt); continue; } @@ -147,10 +145,8 @@ ContentDialog::~ContentDialog() auto groupIt = groupList.begin(); - while (groupIt != groupList.end()) - { - if (std::get<0>(groupIt.value()) == this) - { + while (groupIt != groupList.end()) { + if (std::get<0>(groupIt.value()) == this) { groupIt = groupList.erase(groupIt); continue; } @@ -168,10 +164,14 @@ FriendWidget* ContentDialog::addFriend(int friendId, QString id) Friend* frnd = friendWidget->getFriend(); connect(frnd, &Friend::aliasChanged, this, &ContentDialog::updateFriendWidget); - connect(friendWidget, &FriendWidget::chatroomWidgetClicked, this, &ContentDialog::onChatroomWidgetClicked); - connect(friendWidget, SIGNAL(chatroomWidgetClicked(GenericChatroomWidget*)), frnd->getChatForm(), SLOT(focusInput())); - connect(Core::getInstance(), &Core::friendAvatarChanged, friendWidget, &FriendWidget::onAvatarChange); - connect(Core::getInstance(), &Core::friendAvatarRemoved, friendWidget, &FriendWidget::onAvatarRemoved); + connect(friendWidget, &FriendWidget::chatroomWidgetClicked, this, + &ContentDialog::onChatroomWidgetClicked); + connect(friendWidget, SIGNAL(chatroomWidgetClicked(GenericChatroomWidget*)), + frnd->getChatForm(), SLOT(focusInput())); + connect(Core::getInstance(), &Core::friendAvatarChanged, friendWidget, + &FriendWidget::onAvatarChange); + connect(Core::getInstance(), &Core::friendAvatarRemoved, friendWidget, + &FriendWidget::onAvatarRemoved); ContentDialog* lastDialog = getFriendDialog(friendId); @@ -193,7 +193,8 @@ GroupWidget* ContentDialog::addGroup(int groupId, const QString& name) Group* group = groupWidget->getGroup(); connect(group, &Group::titleChanged, this, &ContentDialog::updateGroupWidget); connect(group, &Group::userListChanged, this, &ContentDialog::updateGroupWidget); - connect(groupWidget, &GroupWidget::chatroomWidgetClicked, this, &ContentDialog::onChatroomWidgetClicked); + connect(groupWidget, &GroupWidget::chatroomWidgetClicked, this, + &ContentDialog::onChatroomWidgetClicked); ContentDialog* lastDialog = getGroupDialog(groupId); @@ -215,8 +216,8 @@ void ContentDialog::removeFriend(int friendId) return; FriendWidget* chatroomWidget = static_cast(std::get<1>(iter.value())); - disconnect(chatroomWidget->getFriend(), &Friend::aliasChanged, - this, &ContentDialog::updateFriendWidget); + disconnect(chatroomWidget->getFriend(), &Friend::aliasChanged, this, + &ContentDialog::updateFriendWidget); // Need to find replacement to show here instead. if (activeChatroomWidget == chatroomWidget) @@ -228,14 +229,11 @@ void ContentDialog::removeFriend(int friendId) chatroomWidget->deleteLater(); friendList.remove(friendId); - if (chatroomWidgetCount() == 0) - { + if (chatroomWidgetCount() == 0) { contentLayout->clear(); activeChatroomWidget = nullptr; deleteLater(); - } - else - { + } else { update(); } } @@ -244,8 +242,7 @@ void ContentDialog::removeGroup(int groupId) { Group* group = GroupList::findGroup(groupId); - if (group) - { + if (group) { disconnect(group, &Group::titleChanged, this, &ContentDialog::updateGroupWidget); disconnect(group, &Group::userListChanged, this, &ContentDialog::updateGroupWidget); } @@ -265,14 +262,11 @@ void ContentDialog::removeGroup(int groupId) chatroomWidget->deleteLater(); groupList.remove(groupId); - if (chatroomWidgetCount() == 0) - { + if (chatroomWidgetCount() == 0) { contentLayout->clear(); activeChatroomWidget = nullptr; deleteLater(); - } - else - { + } else { update(); } } @@ -282,7 +276,7 @@ bool ContentDialog::hasFriendWidget(int friendId, GenericChatroomWidget* chatroo return hasWidget(friendId, chatroomWidget, friendList); } -bool ContentDialog::hasGroupWidget(int groupId, GenericChatroomWidget *chatroomWidget) +bool ContentDialog::hasGroupWidget(int groupId, GenericChatroomWidget* chatroomWidget) { return hasWidget(groupId, chatroomWidget, groupList); } @@ -306,59 +300,50 @@ void ContentDialog::cycleContacts(bool forward, bool loop) int index; QLayout* currentLayout; - if (activeChatroomWidget->getFriend()) - { + if (activeChatroomWidget->getFriend()) { currentLayout = friendLayout->getLayoutOnline(); index = friendLayout->indexOfFriendWidget(activeChatroomWidget, true); - if (index == -1) - { + if (index == -1) { currentLayout = friendLayout->getLayoutOffline(); index = friendLayout->indexOfFriendWidget(activeChatroomWidget, false); } - } - else - { + } else { currentLayout = groupLayout.getLayout(); index = groupLayout.indexOfSortedWidget(activeChatroomWidget); } - if (!loop && index == currentLayout->count() - 1) - { + if (!loop && index == currentLayout->count() - 1) { bool groupsOnTop = Settings::getInstance().getGroupchatPosition(); bool offlineEmpty = friendLayout->getLayoutOffline()->isEmpty(); - bool onlineEmpty = offlineEmpty && (friendLayout->getLayoutOnline()->isEmpty() || !groupsOnTop); + bool onlineEmpty = + offlineEmpty && (friendLayout->getLayoutOnline()->isEmpty() || !groupsOnTop); bool groupsEmpty = offlineEmpty && (groupLayout.getLayout()->isEmpty() || groupsOnTop); if ((currentLayout == friendLayout->getLayoutOffline()) || (currentLayout == friendLayout->getLayoutOnline() && groupsEmpty) - || (currentLayout == groupLayout.getLayout() && onlineEmpty)) - { + || (currentLayout == groupLayout.getLayout() && onlineEmpty)) { forward = !forward; } } index += forward ? 1 : -1; - for (;;) - { + for (;;) { // Bounds checking. - if (index < 0) - { + if (index < 0) { currentLayout = nextLayout(currentLayout, forward); index = currentLayout->count() - 1; continue; - } - else if (index >= currentLayout->count()) - { + } else if (index >= currentLayout->count()) { currentLayout = nextLayout(currentLayout, forward); index = 0; continue; } - GenericChatroomWidget* chatWidget = qobject_cast(currentLayout->itemAt(index)->widget()); + GenericChatroomWidget* chatWidget = + qobject_cast(currentLayout->itemAt(index)->widget()); - if (chatWidget != nullptr && chatWidget != activeChatroomWidget) - { + if (chatWidget != nullptr && chatWidget != activeChatroomWidget) { // FIXME: emit should be removed emit chatWidget->chatroomWidgetClicked(chatWidget, false); } @@ -408,14 +393,15 @@ void ContentDialog::updateFriendStatus(int friendId) { updateStatus(friendId, friendList); ContentDialog* contentDialog = getFriendDialog(friendId); - if (contentDialog != nullptr) - { - FriendWidget* friendWidget = static_cast(std::get<1>(friendList.find(friendId).value())); - contentDialog->friendLayout->addFriendWidget(friendWidget, FriendList::findFriend(friendId)->getStatus()); + if (contentDialog != nullptr) { + FriendWidget* friendWidget = + static_cast(std::get<1>(friendList.find(friendId).value())); + contentDialog->friendLayout->addFriendWidget(friendWidget, + FriendList::findFriend(friendId)->getStatus()); } } -void ContentDialog::updateFriendStatusMessage(int friendId, const QString &message) +void ContentDialog::updateFriendStatusMessage(int friendId, const QString& message) { auto iter = friendList.find(friendId); @@ -452,36 +438,33 @@ ContentDialog* ContentDialog::getGroupDialog(int groupId) void ContentDialog::updateTitleAndStatusIcon(const QString& username) { - if (displayWidget != nullptr) - { + if (displayWidget != nullptr) { setWindowTitle(displayWidget->getTitle() + QStringLiteral(" - ") + username); // it's null when it's a groupchat - if (displayWidget->getFriend() == nullptr) - { + if (displayWidget->getFriend() == nullptr) { setWindowIcon(QIcon(":/img/group.svg")); return; } Status currentStatus = displayWidget->getFriend()->getStatus(); - switch(currentStatus) { - case Status::Online: - setWindowIcon(QIcon(":/img/status/dot_online.svg")); - break; - case Status::Away: - setWindowIcon(QIcon(":/img/status/dot_away.svg")); - break; - case Status::Busy: - setWindowIcon(QIcon(":/img/status/dot_busy.svg")); - break; - case Status::Offline: - setWindowIcon(QIcon(":/img/status/dot_offline.svg")); - break; + switch (currentStatus) { + case Status::Online: + setWindowIcon(QIcon(":/img/status/dot_online.svg")); + break; + case Status::Away: + setWindowIcon(QIcon(":/img/status/dot_away.svg")); + break; + case Status::Busy: + setWindowIcon(QIcon(":/img/status/dot_busy.svg")); + break; + case Status::Offline: + setWindowIcon(QIcon(":/img/status/dot_offline.svg")); + break; } - } - else + } else setWindowTitle(username); } @@ -503,11 +486,9 @@ void ContentDialog::nextContact() bool ContentDialog::event(QEvent* event) { - switch (event->type()) - { + switch (event->type()) { case QEvent::WindowActivate: - if (activeChatroomWidget != nullptr) - { + if (activeChatroomWidget != nullptr) { activeChatroomWidget->resetEventFlags(); activeChatroomWidget->updateStatusLight(); updateTitle(activeChatroomWidget); @@ -515,12 +496,9 @@ bool ContentDialog::event(QEvent* event) Friend* frnd = activeChatroomWidget->getFriend(); Group* group = activeChatroomWidget->getGroup(); - if (frnd) - { + if (frnd) { emit friendDialogShown(frnd); - } - else if (group) - { + } else if (group) { emit groupDialogShown(group); } } @@ -537,15 +515,14 @@ bool ContentDialog::event(QEvent* event) return ActivateDialog::event(event); } -void ContentDialog::dragEnterEvent(QDragEnterEvent *event) +void ContentDialog::dragEnterEvent(QDragEnterEvent* event) { - QObject *o = event->source(); - FriendWidget *frnd = qobject_cast(o); - GroupWidget *group = qobject_cast(o); - if (frnd) - { + QObject* o = event->source(); + FriendWidget* frnd = qobject_cast(o); + GroupWidget* group = qobject_cast(o); + if (frnd) { ToxId toxId(event->mimeData()->text()); - Friend *contact = FriendList::findFriend(toxId.getPublicKey()); + Friend* contact = FriendList::findFriend(toxId.getPublicKey()); if (!contact) return; @@ -555,14 +532,12 @@ void ContentDialog::dragEnterEvent(QDragEnterEvent *event) // If friend is already in a dialog then you can't drop friend where it already is. if (iter == friendList.end() || std::get<0>(iter.value()) != this) event->acceptProposedAction(); - } - else if (group) - { + } else if (group) { if (!event->mimeData()->hasFormat("groupId")) return; int groupId = event->mimeData()->data("groupId").toInt(); - Group *contact = GroupList::findGroup(groupId); + Group* contact = GroupList::findGroup(groupId); if (!contact) return; @@ -572,15 +547,14 @@ void ContentDialog::dragEnterEvent(QDragEnterEvent *event) } } -void ContentDialog::dropEvent(QDropEvent *event) +void ContentDialog::dropEvent(QDropEvent* event) { - QObject *o = event->source(); - FriendWidget *frnd = qobject_cast(o); - GroupWidget *group = qobject_cast(o); - if (frnd) - { + QObject* o = event->source(); + FriendWidget* frnd = qobject_cast(o); + GroupWidget* group = qobject_cast(o); + if (frnd) { ToxId toxId(event->mimeData()->text()); - Friend *contact = FriendList::findFriend(toxId.getPublicKey()); + Friend* contact = FriendList::findFriend(toxId.getPublicKey()); if (!contact) return; @@ -591,14 +565,12 @@ void ContentDialog::dropEvent(QDropEvent *event) Widget::getInstance()->addFriendDialog(contact, this); ensureSplitterVisible(); - } - else if (group) - { + } else if (group) { if (!event->mimeData()->hasFormat("groupId")) return; int groupId = event->mimeData()->data("groupId").toInt(); - Group *contact = GroupList::findGroup(groupId); + Group* contact = GroupList::findGroup(groupId); if (!contact) return; @@ -611,11 +583,10 @@ void ContentDialog::dropEvent(QDropEvent *event) } } -void ContentDialog::changeEvent(QEvent *event) +void ContentDialog::changeEvent(QEvent* event) { QWidget::changeEvent(event); - if (event->type() == QEvent::ActivationChange) - { + if (event->type() == QEvent::ActivationChange) { if (isActiveWindow()) currentDialog = this; } @@ -639,20 +610,16 @@ void ContentDialog::keyPressEvent(QKeyEvent* event) QDialog::keyPressEvent(event); // Ignore escape keyboard shortcut. } -void ContentDialog::onChatroomWidgetClicked(GenericChatroomWidget *widget, bool group) +void ContentDialog::onChatroomWidgetClicked(GenericChatroomWidget* widget, bool group) { - if (group) - { + if (group) { ContentDialog* contentDialog = new ContentDialog(settingsWidget); contentDialog->show(); - if (widget->getFriend() != nullptr) - { + if (widget->getFriend() != nullptr) { removeFriend(widget->getFriend()->getFriendId()); Widget::getInstance()->addFriendDialog(widget->getFriend(), contentDialog); - } - else - { + } else { removeGroup(widget->getGroup()->getGroupId()); Widget::getInstance()->addGroupDialog(widget->getGroup(), contentDialog); } @@ -683,8 +650,8 @@ void ContentDialog::onChatroomWidgetClicked(GenericChatroomWidget *widget, bool void ContentDialog::updateFriendWidget(uint32_t friendId, QString alias) { - Friend *f = FriendList::findFriend(friendId); - GenericChatroomWidget *widget = std::get<1>(friendList.find(friendId).value()); + Friend* f = FriendList::findFriend(friendId); + GenericChatroomWidget* widget = std::get<1>(friendList.find(friendId).value()); FriendWidget* friendWidget = static_cast(widget); friendWidget->setName(alias); @@ -692,7 +659,7 @@ void ContentDialog::updateFriendWidget(uint32_t friendId, QString alias) friendLayout->addFriendWidget(friendWidget, status); } -void ContentDialog::updateGroupWidget(GroupWidget *w) +void ContentDialog::updateGroupWidget(GroupWidget* w) { std::get<1>(groupList.find(w->groupId).value())->setName(w->getName()); static_cast(std::get<1>(groupList.find(w->groupId).value()))->onUserListChanged(); @@ -723,7 +690,8 @@ void ContentDialog::saveSplitterState() Settings::getInstance().setDialogSplitterState(splitter->saveState()); } -bool ContentDialog::hasWidget(int id, GenericChatroomWidget* chatroomWidget, const QHash>& list) +bool ContentDialog::hasWidget(int id, GenericChatroomWidget* chatroomWidget, + const QHash>& list) { auto iter = list.find(id); @@ -733,14 +701,14 @@ bool ContentDialog::hasWidget(int id, GenericChatroomWidget* chatroomWidget, con return chatroomWidget == std::get<1>(iter.value()); } -bool ContentDialog::existsWidget(int id, bool focus, const QHash>& list) +bool ContentDialog::existsWidget(int id, bool focus, + const QHash>& list) { auto iter = list.find(id); if (iter == list.end()) return false; - if (focus) - { + if (focus) { if (std::get<0>(iter.value())->windowState() & Qt::WindowMinimized) std::get<0>(iter.value())->showNormal(); @@ -752,7 +720,8 @@ bool ContentDialog::existsWidget(int id, bool focus, const QHash > &list) +void ContentDialog::updateStatus(int id, + const QHash>& list) { auto iter = list.find(id); @@ -766,7 +735,8 @@ void ContentDialog::updateStatus(int id, const QHash(iter.value())->updateTitle(chatroomWidget); } -bool ContentDialog::isWidgetActive(int id, const QHash > &list) +bool ContentDialog::isWidgetActive( + int id, const QHash>& list) { auto iter = list.find(id); @@ -776,7 +746,9 @@ bool ContentDialog::isWidgetActive(int id, const QHash(iter.value())->activeChatroomWidget == std::get<1>(iter.value()); } -ContentDialog* ContentDialog::getDialog(int id, const QHash>& list) +ContentDialog* +ContentDialog::getDialog(int id, + const QHash>& list) { auto iter = list.find(id); @@ -788,51 +760,37 @@ ContentDialog* ContentDialog::getDialog(int id, const QHashgetLayoutOnline(); return friendLayout->getLayoutOffline(); - } - else - { + } else { if (Settings::getInstance().getGroupchatPosition()) return friendLayout->getLayoutOffline(); return friendLayout->getLayoutOnline(); } - } - else if (layout == friendLayout->getLayoutOnline()) - { - if (forward) - { + } else if (layout == friendLayout->getLayoutOnline()) { + if (forward) { if (Settings::getInstance().getGroupchatPosition()) return friendLayout->getLayoutOffline(); return groupLayout.getLayout(); - } - else - { + } else { if (Settings::getInstance().getGroupchatPosition()) return groupLayout.getLayout(); return friendLayout->getLayoutOffline(); } - } - else if (layout == friendLayout->getLayoutOffline()) - { - if (forward) - { + } else if (layout == friendLayout->getLayoutOffline()) { + if (forward) { if (Settings::getInstance().getGroupchatPosition()) return groupLayout.getLayout(); return friendLayout->getLayoutOnline(); - } - else - { + } else { if (Settings::getInstance().getGroupchatPosition()) return friendLayout->getLayoutOnline(); diff --git a/src/widget/contentdialog.h b/src/widget/contentdialog.h index 2ebd137b7..0dcea104a 100644 --- a/src/widget/contentdialog.h +++ b/src/widget/contentdialog.h @@ -26,8 +26,10 @@ #include "src/widget/genericchatitemlayout.h" #include "src/widget/tool/activatedialog.h" -template class QHash; -template class QSet; +template +class QHash; +template +class QSet; class QSplitter; class QVBoxLayout; @@ -64,7 +66,7 @@ public: static bool existsFriendWidget(int friendId, bool focus); static bool existsGroupWidget(int groupId, bool focus); static void updateFriendStatus(int friendId); - static void updateFriendStatusMessage(int friendId, const QString &message); + static void updateFriendStatusMessage(int friendId, const QString& message); static void updateGroupStatus(int groupId); static bool isFriendWidgetActive(int friendId); static bool isGroupWidgetActive(int groupId); @@ -103,11 +105,16 @@ private: void saveSplitterState(); QLayout* nextLayout(QLayout* layout, bool forward) const; - bool hasWidget(int id, GenericChatroomWidget* chatroomWidget, const QHash>& list); - static bool existsWidget(int id, bool focus, const QHash>& list); - static void updateStatus(int id, const QHash>& list); - static bool isWidgetActive(int id, const QHash>& list); - static ContentDialog* getDialog(int id, const QHash>& list); + bool hasWidget(int id, GenericChatroomWidget* chatroomWidget, + const QHash>& list); + static bool existsWidget(int id, bool focus, + const QHash>& list); + static void + updateStatus(int id, const QHash>& list); + static bool + isWidgetActive(int id, const QHash>& list); + static ContentDialog* + getDialog(int id, const QHash>& list); QSplitter* splitter; FriendListLayout* friendLayout; diff --git a/src/widget/contentlayout.cpp b/src/widget/contentlayout.cpp index eff4b5e48..45ae42222 100644 --- a/src/widget/contentlayout.cpp +++ b/src/widget/contentlayout.cpp @@ -18,10 +18,10 @@ */ #include "contentlayout.h" -#include "src/persistence/settings.h" #include "style.h" -#include +#include "src/persistence/settings.h" #include +#include ContentLayout::ContentLayout() : QVBoxLayout() @@ -69,15 +69,13 @@ ContentLayout::~ContentLayout() void ContentLayout::clear() { QLayoutItem* item; - while ((item = mainHead->layout()->takeAt(0)) != 0) - { + while ((item = mainHead->layout()->takeAt(0)) != 0) { item->widget()->hide(); item->widget()->setParent(nullptr); delete item; } - while ((item = mainContent->layout()->takeAt(0)) != 0) - { + while ((item = mainContent->layout()->takeAt(0)) != 0) { item->widget()->hide(); item->widget()->setParent(nullptr); delete item; @@ -108,8 +106,7 @@ void ContentLayout::init() mainContent->setSizePolicy(QSizePolicy::MinimumExpanding, QSizePolicy::MinimumExpanding); if (QStyleFactory::keys().contains(Settings::getInstance().getStyle()) - && Settings::getInstance().getStyle() != "None") - { + && Settings::getInstance().getStyle() != "None") { mainHead->setStyle(QStyleFactory::create(Settings::getInstance().getStyle())); mainContent->setStyle(QStyleFactory::create(Settings::getInstance().getStyle())); } diff --git a/src/widget/emoticonswidget.cpp b/src/widget/emoticonswidget.cpp index 8dd2f1afa..574929f8f 100644 --- a/src/widget/emoticonswidget.cpp +++ b/src/widget/emoticonswidget.cpp @@ -18,21 +18,21 @@ */ #include "emoticonswidget.h" -#include "src/widget/style.h" -#include "src/persistence/smileypack.h" #include "src/persistence/settings.h" +#include "src/persistence/smileypack.h" +#include "src/widget/style.h" +#include +#include +#include +#include #include #include -#include -#include -#include -#include #include -EmoticonsWidget::EmoticonsWidget(QWidget* parent) : - QMenu(parent) +EmoticonsWidget::EmoticonsWidget(QWidget* parent) + : QMenu(parent) { setStyleSheet(Style::getStylesheet(":/ui/emoticonWidget/emoticonWidget.css")); setLayout(&layout); @@ -62,19 +62,19 @@ EmoticonsWidget::EmoticonsWidget(QWidget* parent) : // create pages buttonLayout->addStretch(); - for (int i = 0; i < pageCount; ++i) - { + for (int i = 0; i < pageCount; ++i) { QGridLayout* pageLayout = new QGridLayout; - pageLayout->addItem(new QSpacerItem(0, 0, QSizePolicy::Minimum, QSizePolicy::Expanding), maxRows, 0); - pageLayout->addItem(new QSpacerItem(0, 0, QSizePolicy::Expanding, QSizePolicy::Minimum), 0, maxCols); + pageLayout->addItem(new QSpacerItem(0, 0, QSizePolicy::Minimum, QSizePolicy::Expanding), + maxRows, 0); + pageLayout->addItem(new QSpacerItem(0, 0, QSizePolicy::Expanding, QSizePolicy::Minimum), 0, + maxCols); QWidget* page = new QWidget; page->setLayout(pageLayout); stack.addWidget(page); // page buttons are only needed if there is more than 1 page - if (pageCount > 1) - { + if (pageCount > 1) { QRadioButton* pageButton = new QRadioButton; pageButton->setProperty("pageIndex", i); pageButton->setCursor(Qt::PointingHandCursor); @@ -86,8 +86,7 @@ EmoticonsWidget::EmoticonsWidget(QWidget* parent) : } buttonLayout->addStretch(); - for (const QStringList& set : emoticons) - { + for (const QStringList& set : emoticons) { QPushButton* button = new QPushButton; button->setIcon(SmileyPack::getInstance().getAsIcon(set[0]).pixmap(size)); button->setToolTip(set.join(" ")); @@ -105,15 +104,13 @@ EmoticonsWidget::EmoticonsWidget(QWidget* parent) : ++currItem; // next row - if (col >= maxCols) - { + if (col >= maxCols) { col = 0; ++row; } // next page - if (currItem >= itemsPerPage) - { + if (currItem >= itemsPerPage) { row = 0; currItem = 0; ++currPage; @@ -128,10 +125,9 @@ void EmoticonsWidget::onSmileyClicked() { // emit insert emoticon QWidget* sender = qobject_cast(QObject::sender()); - if (sender) - { - QString sequence = sender->property("sequence").toString() - .replace("<","<").replace(">",">"); + if (sender) { + QString sequence = + sender->property("sequence").toString().replace("<", "<").replace(">", ">"); emit insertEmoticon(' ' + sequence + ' '); } } @@ -139,8 +135,7 @@ void EmoticonsWidget::onSmileyClicked() void EmoticonsWidget::onPageButtonClicked() { QWidget* sender = qobject_cast(QObject::sender()); - if (sender) - { + if (sender) { int page = sender->property("pageIndex").toInt(); stack.setCurrentIndex(page); } @@ -151,7 +146,7 @@ QSize EmoticonsWidget::sizeHint() const return layout.sizeHint(); } -void EmoticonsWidget::mouseReleaseEvent(QMouseEvent *ev) +void EmoticonsWidget::mouseReleaseEvent(QMouseEvent* ev) { if (!rect().contains(ev->pos())) hide(); @@ -161,39 +156,32 @@ void EmoticonsWidget::mousePressEvent(QMouseEvent*) { } -void EmoticonsWidget::wheelEvent (QWheelEvent *e) +void EmoticonsWidget::wheelEvent(QWheelEvent* e) { - if (e->orientation() == Qt::Vertical) - { - if (e->delta() < 0 ) - { - stack.setCurrentIndex(stack.currentIndex()+1); - } - else - { - stack.setCurrentIndex(stack.currentIndex()-1); - } - emit PageButtonsUpdate(); - + if (e->orientation() == Qt::Vertical) { + if (e->delta() < 0) { + stack.setCurrentIndex(stack.currentIndex() + 1); + } else { + stack.setCurrentIndex(stack.currentIndex() - 1); + } + emit PageButtonsUpdate(); } } void EmoticonsWidget::PageButtonsUpdate() { QList pageButtons = this->findChildren(QString()); - QRadioButton *t_pageButton; - foreach (t_pageButton,pageButtons) - { - if ( t_pageButton->property("pageIndex").toInt()==stack.currentIndex()) - t_pageButton->setChecked(true); - else - t_pageButton->setChecked(false); + QRadioButton* t_pageButton; + foreach (t_pageButton, pageButtons) { + if (t_pageButton->property("pageIndex").toInt() == stack.currentIndex()) + t_pageButton->setChecked(true); + else + t_pageButton->setChecked(false); } } -void EmoticonsWidget::keyPressEvent(QKeyEvent *e) +void EmoticonsWidget::keyPressEvent(QKeyEvent* e) { Q_UNUSED(e) hide(); } - diff --git a/src/widget/emoticonswidget.h b/src/widget/emoticonswidget.h index 5f69e6dcd..d2471ca00 100644 --- a/src/widget/emoticonswidget.h +++ b/src/widget/emoticonswidget.h @@ -39,10 +39,10 @@ private slots: void PageButtonsUpdate(); protected: - void mouseReleaseEvent(QMouseEvent *ev) final override; - void mousePressEvent(QMouseEvent *ev) final override; - void wheelEvent(QWheelEvent * event) final override; - void keyPressEvent(QKeyEvent *e) final override; + void mouseReleaseEvent(QMouseEvent* ev) final override; + void mousePressEvent(QMouseEvent* ev) final override; + void wheelEvent(QWheelEvent* event) final override; + void keyPressEvent(QKeyEvent* e) final override; private: QStackedWidget stack; @@ -50,7 +50,6 @@ private: public: QSize sizeHint() const override; - }; #endif // EMOTICONSWIDGET_H diff --git a/src/widget/flowlayout.cpp b/src/widget/flowlayout.cpp index 66015e27e..336b110b6 100644 --- a/src/widget/flowlayout.cpp +++ b/src/widget/flowlayout.cpp @@ -42,25 +42,28 @@ #include "flowlayout.h" FlowLayout::FlowLayout(QWidget* parent, int margin, int hSpacing, int vSpacing) - : QLayout(parent), m_hSpace(hSpacing), m_vSpace(vSpacing) + : QLayout(parent) + , m_hSpace(hSpacing) + , m_vSpace(vSpacing) { setContentsMargins(margin, margin, margin, margin); } FlowLayout::FlowLayout(int margin, int hSpacing, int vSpacing) - : m_hSpace(hSpacing), m_vSpace(vSpacing) + : m_hSpace(hSpacing) + , m_vSpace(vSpacing) { setContentsMargins(margin, margin, margin, margin); } FlowLayout::~FlowLayout() { - QLayoutItem *item; + QLayoutItem* item; while ((item = takeAt(0))) delete item; } -void FlowLayout::addItem(QLayoutItem *item) +void FlowLayout::addItem(QLayoutItem* item) { itemList.append(item); } @@ -86,12 +89,12 @@ int FlowLayout::count() const return itemList.size(); } -QLayoutItem *FlowLayout::itemAt(int index) const +QLayoutItem* FlowLayout::itemAt(int index) const { return itemList.value(index); } -QLayoutItem *FlowLayout::takeAt(int index) +QLayoutItem* FlowLayout::takeAt(int index) { if (index >= 0 && index < itemList.size()) return itemList.takeAt(index); @@ -115,7 +118,7 @@ int FlowLayout::heightForWidth(int width) const return height; } -void FlowLayout::setGeometry(const QRect &rect) +void FlowLayout::setGeometry(const QRect& rect) { QLayout::setGeometry(rect); doLayout(rect, false); @@ -129,15 +132,15 @@ QSize FlowLayout::sizeHint() const QSize FlowLayout::minimumSize() const { QSize size; - QLayoutItem *item; + QLayoutItem* item; foreach (item, itemList) size = size.expandedTo(item->minimumSize()); - size += QSize(2*margin(), 2*margin()); + size += QSize(2 * margin(), 2 * margin()); return size; } -int FlowLayout::doLayout(const QRect &rect, bool testOnly) const +int FlowLayout::doLayout(const QRect& rect, bool testOnly) const { int left, top, right, bottom; getContentsMargins(&left, &top, &right, &bottom); @@ -146,23 +149,21 @@ int FlowLayout::doLayout(const QRect &rect, bool testOnly) const int y = effectiveRect.y(); int lineHeight = 0; - QLayoutItem *item; - foreach (item, itemList) - { + QLayoutItem* item; + foreach (item, itemList) { QWidget* wid = item->widget(); int spaceX = horizontalSpacing(); if (spaceX == -1) - spaceX = wid->style()->layoutSpacing( - QSizePolicy::PushButton, QSizePolicy::PushButton, Qt::Horizontal); + spaceX = wid->style()->layoutSpacing(QSizePolicy::PushButton, QSizePolicy::PushButton, + Qt::Horizontal); int spaceY = verticalSpacing(); if (spaceY == -1) - spaceY = wid->style()->layoutSpacing( - QSizePolicy::PushButton, QSizePolicy::PushButton, Qt::Vertical); + spaceY = wid->style()->layoutSpacing(QSizePolicy::PushButton, QSizePolicy::PushButton, + Qt::Vertical); int nextX = x + item->sizeHint().width() + spaceX; - if (nextX - spaceX > effectiveRect.right() && lineHeight > 0) - { + if (nextX - spaceX > effectiveRect.right() && lineHeight > 0) { x = effectiveRect.x(); y = y + lineHeight + spaceY; nextX = x + item->sizeHint().width() + spaceX; @@ -179,18 +180,13 @@ int FlowLayout::doLayout(const QRect &rect, bool testOnly) const } int FlowLayout::smartSpacing(QStyle::PixelMetric pm) const { - QObject *parent = this->parent(); - if (!parent) - { + QObject* parent = this->parent(); + if (!parent) { return -1; - } - else if (parent->isWidgetType()) - { - QWidget* pw = static_cast(parent); + } else if (parent->isWidgetType()) { + QWidget* pw = static_cast(parent); return pw->style()->pixelMetric(pm, 0, pw); - } - else - { - return static_cast(parent)->spacing(); + } else { + return static_cast(parent)->spacing(); } } diff --git a/src/widget/flowlayout.h b/src/widget/flowlayout.h index fe3eff721..9835e01ac 100644 --- a/src/widget/flowlayout.h +++ b/src/widget/flowlayout.h @@ -47,28 +47,28 @@ class FlowLayout : public QLayout { public: - explicit FlowLayout(QWidget *parent, int margin = -1, int hSpacing = -1, int vSpacing = -1); + explicit FlowLayout(QWidget* parent, int margin = -1, int hSpacing = -1, int vSpacing = -1); explicit FlowLayout(int margin = -1, int hSpacing = -1, int vSpacing = -1); ~FlowLayout(); - void addItem(QLayoutItem *item); + void addItem(QLayoutItem* item); int horizontalSpacing() const; int verticalSpacing() const; Qt::Orientations expandingDirections() const; bool hasHeightForWidth() const; int heightForWidth(int) const; int count() const; - QLayoutItem *itemAt(int index) const; + QLayoutItem* itemAt(int index) const; QSize minimumSize() const; - void setGeometry(const QRect &rect); + void setGeometry(const QRect& rect); QSize sizeHint() const; - QLayoutItem *takeAt(int index); + QLayoutItem* takeAt(int index); private: - int doLayout(const QRect &rect, bool testOnly) const; + int doLayout(const QRect& rect, bool testOnly) const; int smartSpacing(QStyle::PixelMetric pm) const; - QList itemList; + QList itemList; int m_hSpace; int m_vSpace; }; diff --git a/src/widget/form/addfriendform.cpp b/src/widget/form/addfriendform.cpp index 1f697d71f..fc5160ee6 100644 --- a/src/widget/form/addfriendform.cpp +++ b/src/widget/form/addfriendform.cpp @@ -18,26 +18,26 @@ */ #include "addfriendform.h" -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include "src/nexus.h" #include "src/core/core.h" #include "src/net/toxme.h" -#include "src/persistence/settings.h" -#include "src/widget/gui.h" -#include "src/widget/translator.h" -#include "src/widget/contentlayout.h" -#include "src/widget/tool/croppinglabel.h" #include "src/net/toxme.h" -#include +#include "src/nexus.h" +#include "src/persistence/settings.h" +#include "src/widget/contentlayout.h" +#include "src/widget/gui.h" +#include "src/widget/tool/croppinglabel.h" +#include "src/widget/translator.h" +#include +#include +#include +#include +#include +#include #include +#include +#include +#include +#include /** * @var QString AddFriendForm::lastUsername @@ -79,19 +79,19 @@ AddFriendForm::AddFriendForm() connect(Nexus::getCore(), &Core::usernameSet, this, &AddFriendForm::onUsernameSet); // accessibility stuff - toxIdLabel.setAccessibleDescription(tr("Tox ID, either 76 hexadecimal characters or name@example.com")); + toxIdLabel.setAccessibleDescription( + tr("Tox ID, either 76 hexadecimal characters or name@example.com")); toxId.setAccessibleDescription(tr("Type in Tox ID of your friend")); messageLabel.setAccessibleDescription(tr("Friend request message")); - message.setAccessibleDescription( - tr("Type message to send with the friend request or leave empty to send a default message")); + message.setAccessibleDescription(tr( + "Type message to send with the friend request or leave empty to send a default message")); retranslateUi(); Translator::registerHandler(std::bind(&AddFriendForm::retranslateUi, this), this); int size = Settings::getInstance().getFriendRequestSize(); - for (int i = 0; i < size; ++i) - { + for (int i = 0; i < size; ++i) { Settings::Request request = Settings::getInstance().getFriendRequest(i); addFriendRequestWidget(request.address, request.message); } @@ -106,8 +106,7 @@ AddFriendForm::~AddFriendForm() bool AddFriendForm::isShown() const { - if (head->isVisible()) - { + if (head->isVisible()) { head->window()->windowHandle()->alert(0); return true; } @@ -141,10 +140,9 @@ void AddFriendForm::setMode(Mode mode) tabWidget->setCurrentIndex(mode); } -bool AddFriendForm::addFriendRequest(const QString &friendAddress, const QString &message) +bool AddFriendForm::addFriendRequest(const QString& friendAddress, const QString& message) { - if (Settings::getInstance().addFriendRequest(friendAddress, message)) - { + if (Settings::getInstance().addFriendRequest(friendAddress, message)) { addFriendRequestWidget(friendAddress, message); if (isShown()) onCurrentChanged(tabWidget->currentIndex()); @@ -165,11 +163,9 @@ void AddFriendForm::onSendTriggered() QString idText = toxId.text().trimmed(); ToxId friendId(idText); - if (!friendId.isValid()) - { + if (!friendId.isValid()) { friendId = Toxme::lookup(idText); // Try Toxme - if (!friendId.isValid()) - { + if (!friendId.isValid()) { GUI::showWarning(tr("Couldn't add friend"), tr("This Tox ID is invalid or does not exist", "Toxme error")); return; @@ -188,31 +184,25 @@ void AddFriendForm::onSendTriggered() this->message.clear(); } -void AddFriendForm::onIdChanged(const QString &id) +void AddFriendForm::onIdChanged(const QString& id) { QString tId = id.trimmed(); QRegularExpression dnsIdExpression("^\\S+@\\S+$"); bool isValidId = tId.isEmpty() || ToxId::isToxId(tId) || tId.contains(dnsIdExpression); QString toxIdText(tr("Tox ID", "Tox ID of the person you're sending a friend request to")); - QString toxIdComment(tr("either 76 hexadecimal characters or name@example.com", "Tox ID format description")); + QString toxIdComment( + tr("either 76 hexadecimal characters or name@example.com", "Tox ID format description")); - if (isValidId) - { - toxIdLabel.setText(toxIdText + - QStringLiteral(" (") + - toxIdComment + - QStringLiteral(")")); - } - else - { - toxIdLabel.setText(toxIdText + - QStringLiteral(" (") + - toxIdComment + - QStringLiteral(")")); + if (isValidId) { + toxIdLabel.setText(toxIdText + QStringLiteral(" (") + toxIdComment + QStringLiteral(")")); + } else { + toxIdLabel.setText(toxIdText + QStringLiteral(" (") + toxIdComment + + QStringLiteral(")")); } - toxId.setStyleSheet(isValidId ? QStringLiteral("") : QStringLiteral("QLineEdit { background-color: #FFC1C1; }")); + toxId.setStyleSheet(isValidId ? QStringLiteral("") + : QStringLiteral("QLineEdit { background-color: #FFC1C1; }")); toxId.setToolTip(isValidId ? QStringLiteral("") : tr("Invalid Tox ID format")); sendButton.setEnabled(isValidId && !tId.isEmpty()); @@ -223,10 +213,7 @@ void AddFriendForm::setIdFromClipboard() QClipboard* clipboard = QApplication::clipboard(); QString id = clipboard->text().trimmed(); const Core* core = Core::getInstance(); - if (core->isReady() && !id.isEmpty() - && ToxId::isToxId(id) - && ToxId(id) != core->getSelfId()) - { + if (core->isReady() && !id.isEmpty() && ToxId::isToxId(id) && ToxId(id) != core->getSelfId()) { toxId.setText(id); } } @@ -234,11 +221,9 @@ void AddFriendForm::setIdFromClipboard() void AddFriendForm::deleteFriendRequest(const ToxId& toxId) { int size = Settings::getInstance().getFriendRequestSize(); - for (int i = 0; i < size; ++i) - { + for (int i = 0; i < size; ++i) { Settings::Request request = Settings::getInstance().getFriendRequest(i); - if (toxId == ToxId(request.address)) - { + if (toxId == ToxId(request.address)) { Settings::getInstance().removeFriendRequest(i); return; } @@ -251,7 +236,8 @@ void AddFriendForm::onFriendRequestAccepted() QWidget* friendWidget = acceptButton->parentWidget(); int index = requestsLayout->indexOf(friendWidget); removeFriendRequestWidget(friendWidget); - Settings::Request request = Settings::getInstance().getFriendRequest(requestsLayout->count() - index - 1); + Settings::Request request = + Settings::getInstance().getFriendRequest(requestsLayout->count() - index - 1); emit friendRequestAccepted(ToxId(request.address).getPublicKey()); Settings::getInstance().removeFriendRequest(requestsLayout->count() - index - 1); Settings::getInstance().savePersonal(); @@ -269,8 +255,7 @@ void AddFriendForm::onFriendRequestRejected() void AddFriendForm::onCurrentChanged(int index) { - if (index == FriendRequest && Settings::getInstance().getUnreadFriendRequests() != 0) - { + if (index == FriendRequest && Settings::getInstance().getUnreadFriendRequests() != 0) { Settings::getInstance().clearUnreadFriendRequests(); Settings::getInstance().savePersonal(); emit friendRequestsSeen(); @@ -280,11 +265,12 @@ void AddFriendForm::onCurrentChanged(int index) void AddFriendForm::retranslateUi() { headLabel.setText(tr("Add Friends")); - messageLabel.setText(tr("Message","The message you send in friend requests")); + messageLabel.setText(tr("Message", "The message you send in friend requests")); sendButton.setText(tr("Send friend request")); - message.setPlaceholderText(tr("%1 here! Tox me maybe?", - "Default message in friend requests if the field is left blank. Write something appropriate!") - .arg(lastUsername)); + message.setPlaceholderText(tr("%1 here! Tox me maybe?", "Default message in friend requests if " + "the field is left blank. Write " + "something appropriate!") + .arg(lastUsername)); onIdChanged(toxId.text()); @@ -298,7 +284,7 @@ void AddFriendForm::retranslateUi() retranslateRejectButton(rejectButton); } -void AddFriendForm::addFriendRequestWidget(const QString &friendAddress, const QString &message) +void AddFriendForm::addFriendRequestWidget(const QString& friendAddress, const QString& message) { QWidget* friendWidget = new QWidget(tabWidget); QHBoxLayout* friendLayout = new QHBoxLayout(friendWidget); @@ -313,8 +299,7 @@ void AddFriendForm::addFriendRequestWidget(const QString &friendAddress, const Q QLabel* messageLabel = new QLabel(message); // allow to select text, but treat links as plaintext to prevent phishing - messageLabel->setTextInteractionFlags(Qt::TextSelectableByMouse | - Qt::TextSelectableByKeyboard); + messageLabel->setTextInteractionFlags(Qt::TextSelectableByMouse | Qt::TextSelectableByKeyboard); messageLabel->setTextFormat(Qt::PlainText); messageLabel->setWordWrap(true); horLayout->addWidget(messageLabel, 1); @@ -343,12 +328,12 @@ void AddFriendForm::removeFriendRequestWidget(QWidget* friendWidget) friendWidget->deleteLater(); } -void AddFriendForm::retranslateAcceptButton(QPushButton *acceptButton) +void AddFriendForm::retranslateAcceptButton(QPushButton* acceptButton) { acceptButton->setText(tr("Accept")); } -void AddFriendForm::retranslateRejectButton(QPushButton *rejectButton) +void AddFriendForm::retranslateRejectButton(QPushButton* rejectButton) { rejectButton->setText(tr("Reject")); } diff --git a/src/widget/form/addfriendform.h b/src/widget/form/addfriendform.h index 02d0a750c..e5d78c4dc 100644 --- a/src/widget/form/addfriendform.h +++ b/src/widget/form/addfriendform.h @@ -22,12 +22,12 @@ #include "src/core/toxid.h" -#include #include #include -#include #include #include +#include +#include class QTabWidget; @@ -66,7 +66,7 @@ public slots: private slots: void onSendTriggered(); - void onIdChanged(const QString &id); + void onIdChanged(const QString& id); void onFriendRequestAccepted(); void onFriendRequestRejected(); void onCurrentChanged(int index); @@ -86,7 +86,7 @@ private: QLineEdit toxId; QTextEdit message; QVBoxLayout layout, headLayout; - QWidget* head, *main; + QWidget *head, *main; QString lastUsername; QTabWidget* tabWidget; QVBoxLayout* requestsLayout; diff --git a/src/widget/form/chatform.cpp b/src/widget/form/chatform.cpp index cacbfbaba..e9b3d3e2d 100644 --- a/src/widget/form/chatform.cpp +++ b/src/widget/form/chatform.cpp @@ -106,24 +106,15 @@ ChatForm::ChatForm(Friend* chatFriend) copyStatusAction = statusMessageMenu.addAction(QString(), this, SLOT(onCopyStatusMessage())); const Core* core = Core::getInstance(); - connect(core, &Core::fileReceiveRequested, - this, &ChatForm::onFileRecvRequest); - connect(core, &Core::friendAvatarChanged, - this, &ChatForm::onAvatarChange); - connect(core, &Core::friendAvatarRemoved, - this, &ChatForm::onAvatarRemoved); - connect(core, &Core::fileSendStarted, - this, &ChatForm::startFileSend); - connect(core, &Core::fileSendFailed, - this, &ChatForm::onFileSendFailed); - connect(core, &Core::receiptRecieved, - this, &ChatForm::onReceiptReceived); - connect(core, &Core::friendMessageReceived, - this, &ChatForm::onFriendMessageReceived); - connect(core, &Core::friendTypingChanged, - this, &ChatForm::onFriendTypingChanged); - connect(core, &Core::friendStatusChanged, - this, &ChatForm::onFriendStatusChanged); + connect(core, &Core::fileReceiveRequested, this, &ChatForm::onFileRecvRequest); + connect(core, &Core::friendAvatarChanged, this, &ChatForm::onAvatarChange); + connect(core, &Core::friendAvatarRemoved, this, &ChatForm::onAvatarRemoved); + connect(core, &Core::fileSendStarted, this, &ChatForm::startFileSend); + connect(core, &Core::fileSendFailed, this, &ChatForm::onFileSendFailed); + connect(core, &Core::receiptRecieved, this, &ChatForm::onReceiptReceived); + connect(core, &Core::friendMessageReceived, this, &ChatForm::onFriendMessageReceived); + connect(core, &Core::friendTypingChanged, this, &ChatForm::onFriendTypingChanged); + connect(core, &Core::friendStatusChanged, this, &ChatForm::onFriendStatusChanged); const CoreAV* av = core->getAv(); @@ -131,41 +122,30 @@ ChatForm::ChatForm(Friend* chatFriend) connect(av, &CoreAV::avStart, this, &ChatForm::onAvStart); connect(av, &CoreAV::avEnd, this, &ChatForm::onAvEnd); - connect(sendButton, &QPushButton::clicked, - this, &ChatForm::onSendTriggered); - connect(fileButton, &QPushButton::clicked, - this, &ChatForm::onAttachClicked); - connect(screenshotButton, &QPushButton::clicked, - this, &ChatForm::onScreenshotClicked); - connect(callButton, &QAbstractButton::clicked, - this, &ChatForm::onCallTriggered); - connect(videoButton, &QAbstractButton::clicked, - this, &ChatForm::onVideoCallTriggered); - connect(micButton, &QAbstractButton::clicked, - this, &ChatForm::onMicMuteToggle); - connect(volButton, &QAbstractButton::clicked, - this, &ChatForm::onVolMuteToggle); + connect(sendButton, &QPushButton::clicked, this, &ChatForm::onSendTriggered); + connect(fileButton, &QPushButton::clicked, this, &ChatForm::onAttachClicked); + connect(screenshotButton, &QPushButton::clicked, this, &ChatForm::onScreenshotClicked); + connect(callButton, &QAbstractButton::clicked, this, &ChatForm::onCallTriggered); + connect(videoButton, &QAbstractButton::clicked, this, &ChatForm::onVideoCallTriggered); + connect(micButton, &QAbstractButton::clicked, this, &ChatForm::onMicMuteToggle); + connect(volButton, &QAbstractButton::clicked, this, &ChatForm::onVolMuteToggle); - connect(msgEdit, &ChatTextEdit::enterPressed, - this, &ChatForm::onSendTriggered); - connect(msgEdit, &ChatTextEdit::textChanged, - this, &ChatForm::onTextEditChanged); - connect(statusMessageLabel, &CroppingLabel::customContextMenuRequested, - this, [&](const QPoint& pos) { - if (!statusMessageLabel->text().isEmpty()) - { - QWidget* sender = static_cast(this->sender()); - statusMessageMenu.exec(sender->mapToGlobal(pos)); - } - }); + connect(msgEdit, &ChatTextEdit::enterPressed, this, &ChatForm::onSendTriggered); + connect(msgEdit, &ChatTextEdit::textChanged, this, &ChatForm::onTextEditChanged); + connect(statusMessageLabel, &CroppingLabel::customContextMenuRequested, this, + [&](const QPoint& pos) { + if (!statusMessageLabel->text().isEmpty()) { + QWidget* sender = static_cast(this->sender()); + statusMessageMenu.exec(sender->mapToGlobal(pos)); + } + }); connect(&typingTimer, &QTimer::timeout, this, [=] { Core::getInstance()->sendTyping(f->getFriendId(), false); isTyping = false; }); - connect(nameLabel, &CroppingLabel::editFinished, - this, [=](const QString& newName) { + connect(nameLabel, &CroppingLabel::editFinished, this, [=](const QString& newName) { nameLabel->setText(newName); emit aliasChanged(newName); }); @@ -198,10 +178,8 @@ void ChatForm::onSendTriggered() void ChatForm::onTextEditChanged() { Core* core = Core::getInstance(); - if (!Settings::getInstance().getTypingNotification()) - { - if (isTyping) - { + if (!Settings::getInstance().getTypingNotification()) { + if (isTyping) { core->sendTyping(f->getFriendId(), false); } @@ -209,17 +187,13 @@ void ChatForm::onTextEditChanged() return; } - if (msgEdit->toPlainText().length() > 0) - { + if (msgEdit->toPlainText().length() > 0) { typingTimer.start(3000); - if (!isTyping) - { + if (!isTyping) { isTyping = true; core->sendTyping(f->getFriendId(), isTyping); } - } - else - { + } else { isTyping = false; core->sendTyping(f->getFriendId(), isTyping); } @@ -227,34 +201,27 @@ void ChatForm::onTextEditChanged() void ChatForm::onAttachClicked() { - QStringList paths = QFileDialog::getOpenFileNames( - this, tr("Send a file"), QDir::homePath(), - 0, 0, QFileDialog::DontUseNativeDialog); + QStringList paths = QFileDialog::getOpenFileNames(this, tr("Send a file"), QDir::homePath(), 0, + 0, QFileDialog::DontUseNativeDialog); - if (paths.isEmpty()) - { + if (paths.isEmpty()) { return; } Core* core = Core::getInstance(); - for (QString path : paths) - { + for (QString path : paths) { QFile file(path); - if (!file.exists() || !file.open(QIODevice::ReadOnly)) - { + if (!file.exists() || !file.open(QIODevice::ReadOnly)) { QString fileName = QFileInfo(path).fileName(); - QMessageBox::warning( - this, tr("Unable to open"), - tr("qTox wasn't able to open %1").arg(fileName)); + QMessageBox::warning(this, tr("Unable to open"), + tr("qTox wasn't able to open %1").arg(fileName)); continue; } - if (file.isSequential()) - { - QMessageBox::critical( - this, tr("Bad idea"), - tr("You're trying to send a sequential file," - " which is not going to work!")); + if (file.isSequential()) { + QMessageBox::critical(this, tr("Bad idea"), + tr("You're trying to send a sequential file," + " which is not going to work!")); file.close(); continue; } @@ -269,30 +236,27 @@ void ChatForm::onAttachClicked() void ChatForm::startFileSend(ToxFile file) { - if (file.friendId != f->getFriendId()) - { + if (file.friendId != f->getFriendId()) { return; } QString name; const Core* core = Core::getInstance(); ToxPk self = core->getSelfId().getPublicKey(); - if (previousId != self) - { + if (previousId != self) { name = core->getUsername(); previousId = self; } - insertChatMessage(ChatMessage::createFileTransferMessage( - name, file, true, QDateTime::currentDateTime())); + insertChatMessage( + ChatMessage::createFileTransferMessage(name, file, true, QDateTime::currentDateTime())); Widget::getInstance()->updateFriendActivity(f); } void ChatForm::onFileRecvRequest(ToxFile file) { - if (file.friendId != f->getFriendId()) - { + if (file.friendId != f->getFriendId()) { return; } @@ -300,14 +264,13 @@ void ChatForm::onFileRecvRequest(ToxFile file) QString name; ToxPk friendId = f->getPublicKey(); - if (friendId != previousId) - { + if (friendId != previousId) { name = f->getDisplayedName(); previousId = friendId; } - ChatMessage::Ptr msg = ChatMessage::createFileTransferMessage( - name, file, false, QDateTime::currentDateTime()); + ChatMessage::Ptr msg = + ChatMessage::createFileTransferMessage(name, file, false, QDateTime::currentDateTime()); insertChatMessage(msg); ChatLineContentProxy* proxy = static_cast(msg->getContent(1)); @@ -315,12 +278,10 @@ void ChatForm::onFileRecvRequest(ToxFile file) FileTransferWidget* tfWidget = static_cast(proxy->getWidget()); // there is auto-accept for that conact - if (!Settings::getInstance().getAutoAcceptDir(f->getPublicKey()).isEmpty()) - { + if (!Settings::getInstance().getAutoAcceptDir(f->getPublicKey()).isEmpty()) { tfWidget->autoAcceptTransfer(Settings::getInstance().getAutoAcceptDir(f->getPublicKey())); - } - else if (Settings::getInstance().getAutoSaveEnabled()) - { //global autosave to global directory + } else if (Settings::getInstance().getAutoSaveEnabled()) { // global autosave to global + // directory tfWidget->autoAcceptTransfer(Settings::getInstance().getGlobalAutoAcceptDir()); } @@ -329,40 +290,39 @@ void ChatForm::onFileRecvRequest(ToxFile file) void ChatForm::onAvInvite(uint32_t friendId, bool video) { - if (friendId != f->getFriendId()) - { + if (friendId != f->getFriendId()) { return; } callConfirm = new CallConfirmWidget(video ? videoButton : callButton, *f); - insertChatMessage(ChatMessage::createChatInfoMessage( - tr("%1 calling").arg(f->getDisplayedName()), - ChatMessage::INFO, QDateTime::currentDateTime())); + insertChatMessage(ChatMessage::createChatInfoMessage(tr("%1 calling").arg(f->getDisplayedName()), + ChatMessage::INFO, + QDateTime::currentDateTime())); /* AutoAcceptCall is set for this friend */ - if ((video && Settings::getInstance().getAutoAcceptCall(f->getPublicKey()).testFlag(Settings::AutoAcceptCall::Video)) || - (!video && Settings::getInstance().getAutoAcceptCall(f->getPublicKey()).testFlag(Settings::AutoAcceptCall::Audio))) - { + if ((video + && Settings::getInstance().getAutoAcceptCall(f->getPublicKey()).testFlag(Settings::AutoAcceptCall::Video)) + || (!video + && Settings::getInstance() + .getAutoAcceptCall(f->getPublicKey()) + .testFlag(Settings::AutoAcceptCall::Audio))) { uint32_t friendId = f->getFriendId(); qDebug() << "automatic call answer"; CoreAV* coreav = Core::getInstance()->getAv(); QMetaObject::invokeMethod(coreav, "answerCall", Qt::QueuedConnection, Q_ARG(uint32_t, friendId)); - onAvStart(friendId,video); - } - else - { + onAvStart(friendId, video); + } else { callConfirm->show(); - connect(callConfirm.data(), &CallConfirmWidget::accepted, - this, &ChatForm::onAnswerCallTriggered); - connect(callConfirm.data(), &CallConfirmWidget::rejected, - this, &ChatForm::onRejectCallTriggered); + connect(callConfirm.data(), &CallConfirmWidget::accepted, this, + &ChatForm::onAnswerCallTriggered); + connect(callConfirm.data(), &CallConfirmWidget::rejected, this, + &ChatForm::onRejectCallTriggered); - insertChatMessage(ChatMessage::createChatInfoMessage( - tr("%1 calling").arg(f->getDisplayedName()), - ChatMessage::INFO, - QDateTime::currentDateTime())); + insertChatMessage( + ChatMessage::createChatInfoMessage(tr("%1 calling").arg(f->getDisplayedName()), + ChatMessage::INFO, QDateTime::currentDateTime())); Widget::getInstance()->newFriendMessageAlert(friendId, false); Audio& audio = Audio::getInstance(); @@ -373,17 +333,13 @@ void ChatForm::onAvInvite(uint32_t friendId, bool video) void ChatForm::onAvStart(uint32_t friendId, bool video) { - if (friendId != f->getFriendId()) - { + if (friendId != f->getFriendId()) { return; } - if (video) - { + if (video) { showNetcam(); - } - else - { + } else { hideNetcam(); } @@ -393,16 +349,14 @@ void ChatForm::onAvStart(uint32_t friendId, bool video) void ChatForm::onAvEnd(uint32_t friendId) { - if (friendId != f->getFriendId()) - { + if (friendId != f->getFriendId()) { return; } delete callConfirm; - //Fixes an OS X bug with ending a call while in full screen - if (netcam && netcam->isFullScreen()) - { + // Fixes an OS X bug with ending a call while in full screen + if (netcam && netcam->isFullScreen()) { netcam->showNormal(); } @@ -415,21 +369,19 @@ void ChatForm::onAvEnd(uint32_t friendId) void ChatForm::showOutgoingCall(bool video) { - if (video) - { + if (video) { videoButton->setObjectName("yellow"); - videoButton->setStyleSheet(Style::getStylesheet(QStringLiteral(":/ui/videoButton/videoButton.css"))); + videoButton->setStyleSheet( + Style::getStylesheet(QStringLiteral(":/ui/videoButton/videoButton.css"))); videoButton->setToolTip(tr("Cancel video call")); - } - else - { + } else { callButton->setObjectName("yellow"); - callButton->setStyleSheet(Style::getStylesheet(QStringLiteral(":/ui/callButton/callButton.css"))); + callButton->setStyleSheet( + Style::getStylesheet(QStringLiteral(":/ui/callButton/callButton.css"))); callButton->setToolTip(tr("Cancel audio call")); } - addSystemInfoMessage(tr("Calling %1").arg(f->getDisplayedName()), - ChatMessage::INFO, + addSystemInfoMessage(tr("Calling %1").arg(f->getDisplayedName()), ChatMessage::INFO, QDateTime::currentDateTime()); Widget::getInstance()->updateFriendActivity(f); @@ -444,8 +396,7 @@ void ChatForm::onAnswerCallTriggered() updateCallButtons(); CoreAV* av = Core::getInstance()->getAv(); - if (!av->answerCall(f->getFriendId())) - { + if (!av->answerCall(f->getFriendId())) { updateCallButtons(); stopCounter(); hideNetcam(); @@ -468,12 +419,9 @@ void ChatForm::onRejectCallTriggered() void ChatForm::onCallTriggered() { CoreAV* av = Core::getInstance()->getAv(); - if (av->isCallStarted(f)) - { + if (av->isCallStarted(f)) { av->cancelCall(f->getFriendId()); - } - else if (av->startCall(f->getFriendId(), false)) - { + } else if (av->startCall(f->getFriendId(), false)) { showOutgoingCall(false); } } @@ -481,16 +429,12 @@ void ChatForm::onCallTriggered() void ChatForm::onVideoCallTriggered() { CoreAV* av = Core::getInstance()->getAv(); - if (av->isCallStarted(f)) - { + if (av->isCallStarted(f)) { // TODO: We want to activate video on the active call. - if (av->isCallVideoEnabled(f)) - { + if (av->isCallVideoEnabled(f)) { av->cancelCall(f->getFriendId()); } - } - else if (av->startCall(f->getFriendId(), true)) - { + } else if (av->startCall(f->getFriendId(), true)) { showOutgoingCall(true); } } @@ -502,34 +446,30 @@ void ChatForm::updateCallButtons() bool video = av->isCallVideoEnabled(f); callButton->setEnabled(audio && !video); videoButton->setEnabled(video); - if (audio) - { + if (audio) { videoButton->setObjectName(video ? "red" : ""); - videoButton->setToolTip(video ? tr("End video call") : - tr("Can't start video call")); + videoButton->setToolTip(video ? tr("End video call") : tr("Can't start video call")); callButton->setObjectName((audio && !video) ? "red" : ""); - callButton->setToolTip((audio && !video) ? tr("End audio call") : - tr("Can't start audio call")); - } - else - { + callButton->setToolTip((audio && !video) ? tr("End audio call") + : tr("Can't start audio call")); + } else { const Status fs = f->getStatus(); bool online = fs != Status::Offline; callButton->setEnabled(online); videoButton->setEnabled(online); callButton->setObjectName(online ? "green" : ""); - callButton->setToolTip(online ? tr("Start audio call") : - tr("Can't start audio call")); + callButton->setToolTip(online ? tr("Start audio call") : tr("Can't start audio call")); videoButton->setObjectName(online ? "green" : ""); - videoButton->setToolTip(online ? tr("Start video call") : - tr("Can't start video call")); + videoButton->setToolTip(online ? tr("Start video call") : tr("Can't start video call")); } - callButton->setStyleSheet(Style::getStylesheet(QStringLiteral(":/ui/callButton/callButton.css"))); - videoButton->setStyleSheet(Style::getStylesheet(QStringLiteral(":/ui/videoButton/videoButton.css"))); + callButton->setStyleSheet( + Style::getStylesheet(QStringLiteral(":/ui/callButton/callButton.css"))); + videoButton->setStyleSheet( + Style::getStylesheet(QStringLiteral(":/ui/videoButton/videoButton.css"))); updateMuteMicButton(); updateMuteVolButton(); @@ -551,79 +491,73 @@ void ChatForm::onVolMuteToggle() updateMuteVolButton(); } -void ChatForm::onFileSendFailed(uint32_t friendId, const QString &fname) +void ChatForm::onFileSendFailed(uint32_t friendId, const QString& fname) { - if (friendId != f->getFriendId()) - { + if (friendId != f->getFriendId()) { return; } - addSystemInfoMessage(tr("Failed to send file \"%1\"").arg(fname), - ChatMessage::ERROR, QDateTime::currentDateTime()); + addSystemInfoMessage(tr("Failed to send file \"%1\"").arg(fname), ChatMessage::ERROR, + QDateTime::currentDateTime()); } void ChatForm::onFriendStatusChanged(uint32_t friendId, Status status) { // Disable call buttons if friend is offline - if(friendId != f->getFriendId()) - { + if (friendId != f->getFriendId()) { return; } - if (status == Status::Offline) - { + if (status == Status::Offline) { // Hide the "is typing" message when a friend goes offline setFriendTyping(false); - } - else - { + } else { QTimer::singleShot(250, this, SLOT(onDeliverOfflineMessages())); } updateCallButtons(); - if (Settings::getInstance().getStatusChangeNotificationEnabled()) - { + if (Settings::getInstance().getStatusChangeNotificationEnabled()) { QString fStatus = ""; - switch (status) - { + switch (status) { case Status::Away: - fStatus = tr("away", "contact status"); break; + fStatus = tr("away", "contact status"); + break; case Status::Busy: - fStatus = tr("busy", "contact status"); break; + fStatus = tr("busy", "contact status"); + break; case Status::Offline: - fStatus = tr("offline", "contact status"); break; + fStatus = tr("offline", "contact status"); + break; case Status::Online: - fStatus = tr("online", "contact status"); break; + fStatus = tr("online", "contact status"); + break; } addSystemInfoMessage(tr("%1 is now %2", "e.g. \"Dubslow is now online\"") - .arg(f->getDisplayedName()).arg(fStatus), + .arg(f->getDisplayedName()) + .arg(fStatus), ChatMessage::INFO, QDateTime::currentDateTime()); } } void ChatForm::onFriendTypingChanged(quint32 friendId, bool isTyping) { - if (friendId == f->getFriendId()) - { + if (friendId == f->getFriendId()) { setFriendTyping(isTyping); } } void ChatForm::onFriendNameChanged(const QString& name) { - if (sender() == f) - { + if (sender() == f) { setName(name); } } -void ChatForm::onFriendMessageReceived(quint32 friendId, const QString& message, - bool isAction) +void ChatForm::onFriendMessageReceived(quint32 friendId, const QString& message, bool isAction) { - if (friendId != f->getFriendId()) - { + if (friendId != f->getFriendId()) { return; } @@ -633,31 +567,28 @@ void ChatForm::onFriendMessageReceived(quint32 friendId, const QString& message, void ChatForm::onStatusMessage(const QString& message) { - if (sender() == f) - { + if (sender() == f) { setStatusMessage(message); } } void ChatForm::onReceiptReceived(quint32 friendId, int receipt) { - if (friendId == f->getFriendId()) - { + if (friendId == f->getFriendId()) { f->getChatForm()->getOfflineMsgEngine()->dischargeReceipt(receipt); } } -void ChatForm::onAvatarChange(uint32_t friendId, const QPixmap &pic) +void ChatForm::onAvatarChange(uint32_t friendId, const QPixmap& pic) { - if (friendId != f->getFriendId()) - { + if (friendId != f->getFriendId()) { return; } avatar->setPixmap(pic); } -GenericNetCamView *ChatForm::createNetcam() +GenericNetCamView* ChatForm::createNetcam() { qDebug() << "creating netcam"; uint32_t friendId = f->getFriendId(); @@ -668,59 +599,48 @@ GenericNetCamView *ChatForm::createNetcam() return view; } -void ChatForm::dragEnterEvent(QDragEnterEvent *ev) +void ChatForm::dragEnterEvent(QDragEnterEvent* ev) { - if (ev->mimeData()->hasUrls()) - { + if (ev->mimeData()->hasUrls()) { ev->acceptProposedAction(); } } -void ChatForm::dropEvent(QDropEvent *ev) +void ChatForm::dropEvent(QDropEvent* ev) { - if (ev->mimeData()->hasUrls()) - { + if (ev->mimeData()->hasUrls()) { Core* core = Core::getInstance(); - for (QUrl url : ev->mimeData()->urls()) - { + for (QUrl url : ev->mimeData()->urls()) { QFileInfo info(url.path()); QFile file(info.absoluteFilePath()); - if (url.isValid() && !url.isLocalFile() && - url.toString().length() < TOX_MAX_MESSAGE_LENGTH) - { + if (url.isValid() && !url.isLocalFile() + && url.toString().length() < TOX_MAX_MESSAGE_LENGTH) { SendMessageStr(url.toString()); continue; } - if (!file.exists() || !file.open(QIODevice::ReadOnly)) - { + if (!file.exists() || !file.open(QIODevice::ReadOnly)) { info.setFile(url.toLocalFile()); file.setFileName(info.absoluteFilePath()); - if (!file.exists() || !file.open(QIODevice::ReadOnly)) - { + if (!file.exists() || !file.open(QIODevice::ReadOnly)) { QMessageBox::warning(this, tr("Unable to open"), - tr("qTox wasn't able to open %1") - .arg(info.fileName())); + tr("qTox wasn't able to open %1").arg(info.fileName())); continue; } } - if (file.isSequential()) - { - QMessageBox::critical(0, tr("Bad idea"), - tr("You're trying to send a sequential" - " file, which is not going to work!")); + if (file.isSequential()) { + QMessageBox::critical(0, tr("Bad idea"), tr("You're trying to send a sequential" + " file, which is not going to work!")); file.close(); continue; } file.close(); - if (info.exists()) - { - core->sendFile(f->getFriendId(), info.fileName(), - info.absoluteFilePath(), info.size()); + if (info.exists()) { + core->sendFile(f->getFriendId(), info.fileName(), info.absoluteFilePath(), info.size()); } } } @@ -728,8 +648,7 @@ void ChatForm::dropEvent(QDropEvent *ev) void ChatForm::onAvatarRemoved(uint32_t friendId) { - if (friendId != f->getFriendId()) - { + if (friendId != f->getFriendId()) { return; } @@ -749,8 +668,7 @@ void ChatForm::onDeliverOfflineMessages() void ChatForm::onLoadChatHistory() { - if (sender() == f) - { + if (sender() == f) { loadHistory(QDateTime::currentDateTime().addDays(-7), true); } } @@ -760,20 +678,16 @@ void ChatForm::loadHistory(QDateTime since, bool processUndelivered) { QDateTime now = historyBaselineDate.addMSecs(-1); - if (since > now) - { + if (since > now) { return; } - if (!earliestMessage.isNull()) - { - if (earliestMessage < since) - { + if (!earliestMessage.isNull()) { + if (earliestMessage < since) { return; } - if (earliestMessage < now) - { + if (earliestMessage < now) { now = earliestMessage; now = now.addMSecs(-1); } @@ -788,20 +702,16 @@ void ChatForm::loadHistory(QDateTime since, bool processUndelivered) QList historyMessages; - QDate lastDate(1,0,0); - for (const auto &it : msgs) - { + QDate lastDate(1, 0, 0); + for (const auto& it : msgs) { // Show the date every new day QDateTime msgDateTime = it.timestamp.toLocalTime(); QDate msgDate = msgDateTime.date(); - if (msgDate > lastDate) - { + if (msgDate > lastDate) { lastDate = msgDate; QString dateText = msgDate.toString(Settings::getInstance().getDateFormat()); - auto msg = ChatMessage::createChatInfoMessage(dateText, - ChatMessage::INFO, - QDateTime()); + auto msg = ChatMessage::createChatInfoMessage(dateText, ChatMessage::INFO, QDateTime()); historyMessages.append(msg); } @@ -811,16 +721,11 @@ void ChatForm::loadHistory(QDateTime since, bool processUndelivered) QString authorStr; bool isSelf = authorPk == core->getSelfId().getPublicKey(); - if (!it.dispName.isEmpty()) - { + if (!it.dispName.isEmpty()) { authorStr = it.dispName; - } - else if (isSelf) - { + } else if (isSelf) { authorStr = core->getUsername(); - } - else - { + } else { authorStr = resolveToxId(authorPk); } @@ -829,21 +734,18 @@ void ChatForm::loadHistory(QDateTime since, bool processUndelivered) QString messageText = isAction ? it.message.mid(4) : it.message; ChatMessage::MessageType type = isAction ? ChatMessage::ACTION : ChatMessage::NORMAL; - QDateTime dateTime = needSending ? QDateTime() : msgDateTime; - auto msg = ChatMessage::createChatMessage( - authorStr, messageText, type, isSelf, dateTime); + QDateTime dateTime = needSending ? QDateTime() : msgDateTime; + auto msg = ChatMessage::createChatMessage(authorStr, messageText, type, isSelf, dateTime); uint prev = prevMsgDateTime.secsTo(msgDateTime); - if (!isAction && prevId == authorPk && prev < getChatLog()->repNameAfter) - { + if (!isAction && prevId == authorPk && prev < getChatLog()->repNameAfter) { msg->hideSender(); } prevId = authorPk; prevMsgDateTime = msgDateTime; - if (needSending && processUndelivered) - { + if (needSending && processUndelivered) { Core* core = Core::getInstance(); uint32_t friendId = f->getFriendId(); int rec = isAction ? core->sendAction(friendId, msg->toString()) @@ -855,7 +757,8 @@ void ChatForm::loadHistory(QDateTime since, bool processUndelivered) } previousId = storedPrevId; - int savedSliderPos = chatWidget->verticalScrollBar()->maximum() - chatWidget->verticalScrollBar()->value(); + int savedSliderPos = + chatWidget->verticalScrollBar()->maximum() - chatWidget->verticalScrollBar()->value(); earliestMessage = since; @@ -878,8 +781,7 @@ void ChatForm::doScreenshot() // note: grabber is self-managed and will destroy itself when done ScreenshotGrabber* screenshotGrabber = new ScreenshotGrabber; - connect(screenshotGrabber, &ScreenshotGrabber::screenshotTaken, - this, &ChatForm::onScreenshotTaken); + connect(screenshotGrabber, &ScreenshotGrabber::screenshotTaken, this, &ChatForm::onScreenshotTaken); screenshotGrabber->showGrabber(); @@ -887,7 +789,8 @@ void ChatForm::doScreenshot() QDir(Settings::getInstance().getAppDataDirPath()).mkpath("screenshots"); } -void ChatForm::onScreenshotTaken(const QPixmap &pixmap) { +void ChatForm::onScreenshotTaken(const QPixmap& pixmap) +{ // use ~ISO 8601 for screenshot timestamp, considering FS limitations // https://en.wikipedia.org/wiki/ISO_8601 // Windows has to be supported, thus filename can't have `:` in it :/ @@ -899,37 +802,30 @@ void ChatForm::onScreenshotTaken(const QPixmap &pixmap) { QFile file(filepath); - if (file.open(QFile::ReadWrite)) - { + if (file.open(QFile::ReadWrite)) { pixmap.save(&file, "PNG"); qint64 filesize = file.size(); file.close(); QFileInfo fi(file); - Core::getInstance()->sendFile(f->getFriendId(), fi.fileName(), - fi.filePath(), filesize); - } - else - { + Core::getInstance()->sendFile(f->getFriendId(), fi.fileName(), fi.filePath(), filesize); + } else { QMessageBox::warning(this, - tr("Failed to open temporary file", - "Temporary file for screenshot"), + tr("Failed to open temporary file", "Temporary file for screenshot"), tr("qTox wasn't able to save the screenshot")); } } void ChatForm::onLoadHistory() { - if (!Nexus::getProfile()->isHistoryEnabled()) - { + if (!Nexus::getProfile()->isHistoryEnabled()) { return; } LoadHistoryDialog dlg; - if (dlg.exec()) - { + if (dlg.exec()) { QDateTime fromTime = dlg.getFromDate(); loadHistory(fromTime); } @@ -939,8 +835,7 @@ void ChatForm::insertChatMessage(ChatMessage::Ptr msg) { GenericChatForm::insertChatMessage(msg); - if (netcam && bodySplitter->sizes()[1] == 0) - { + if (netcam && bodySplitter->sizes()[1] == 0) { netcam->setShowMessages(true, true); } } @@ -951,8 +846,7 @@ void ChatForm::onCopyStatusMessage() QString text = f->getStatusMessage(); QClipboard* clipboard = QApplication::clipboard(); - if (clipboard) - { + if (clipboard) { clipboard->setText(text, QClipboard::Clipboard); } } @@ -962,21 +856,15 @@ void ChatForm::updateMuteMicButton() const CoreAV* av = Core::getInstance()->getAv(); micButton->setEnabled(av->isCallActive(f)); - if (micButton->isEnabled()) - { - if (av->isCallInputMuted(f)) - { + if (micButton->isEnabled()) { + if (av->isCallInputMuted(f)) { micButton->setObjectName("red"); micButton->setToolTip(tr("Unmute microphone")); - } - else - { + } else { micButton->setObjectName("green"); micButton->setToolTip(tr("Mute microphone")); } - } - else - { + } else { micButton->setObjectName(""); micButton->setToolTip(tr("Microphone can be muted only during a call")); } @@ -991,21 +879,15 @@ void ChatForm::updateMuteVolButton() const CoreAV* av = Core::getInstance()->getAv(); volButton->setEnabled(av->isCallActive(f)); - if (volButton->isEnabled()) - { - if (av->isCallOutputMuted(f)) - { + if (volButton->isEnabled()) { + if (av->isCallOutputMuted(f)) { volButton->setObjectName("red"); volButton->setToolTip(tr("Unmute call")); - } - else - { + } else { volButton->setObjectName("green"); volButton->setToolTip(tr("Mute call")); } - } - else - { + } else { volButton->setObjectName(""); volButton->setToolTip(tr("Sound can be disabled only during a call")); } @@ -1017,11 +899,9 @@ void ChatForm::updateMuteVolButton() void ChatForm::startCounter() { - if (!callDurationTimer) - { + if (!callDurationTimer) { callDurationTimer = new QTimer(); - connect(callDurationTimer, &QTimer::timeout, - this, &ChatForm::onUpdateTime); + connect(callDurationTimer, &QTimer::timeout, this, &ChatForm::onUpdateTime); callDurationTimer->start(1000); timeElapsed.start(); @@ -1031,12 +911,11 @@ void ChatForm::startCounter() void ChatForm::stopCounter() { - if (callDurationTimer) - { - QString dhms = secondsToDHMS(timeElapsed.elapsed()/1000); + if (callDurationTimer) { + QString dhms = secondsToDHMS(timeElapsed.elapsed() / 1000); QString name = f->getDisplayedName(); - addSystemInfoMessage(tr("Call with %1 ended. %2").arg(name, dhms), - ChatMessage::INFO, QDateTime::currentDateTime()); + addSystemInfoMessage(tr("Call with %1 ended. %2").arg(name, dhms), ChatMessage::INFO, + QDateTime::currentDateTime()); callDurationTimer->stop(); callDuration->setText(""); @@ -1049,33 +928,30 @@ void ChatForm::stopCounter() void ChatForm::onUpdateTime() { - callDuration->setText(secondsToDHMS(timeElapsed.elapsed()/1000)); + callDuration->setText(secondsToDHMS(timeElapsed.elapsed() / 1000)); } QString ChatForm::secondsToDHMS(quint32 duration) { QString res; QString cD = tr("Call duration: "); - int seconds = (int) (duration % 60); + int seconds = (int)(duration % 60); duration /= 60; - int minutes = (int) (duration % 60); + int minutes = (int)(duration % 60); duration /= 60; - int hours = (int) (duration % 24); - int days = (int) (duration / 24); + int hours = (int)(duration % 24); + int days = (int)(duration / 24); // I assume no one will ever have call longer than a month - if (days) - { + if (days) { return cD + res.sprintf("%dd%02dh %02dm %02ds", days, hours, minutes, seconds); } - if (hours) - { + if (hours) { return cD + res.sprintf("%02dh %02dm %02ds", hours, minutes, seconds); } - if (minutes) - { + if (minutes) { return cD + res.sprintf("%02dm %02ds", minutes, seconds); } @@ -1095,16 +971,14 @@ void ChatForm::show(ContentLayout* contentLayout) { GenericChatForm::show(contentLayout); - if (callConfirm) - { + if (callConfirm) { callConfirm->show(); } } void ChatForm::showEvent(QShowEvent* event) { - if (callConfirm) - { + if (callConfirm) { callConfirm->show(); } @@ -1113,41 +987,36 @@ void ChatForm::showEvent(QShowEvent* event) void ChatForm::hideEvent(QHideEvent* event) { - if (callConfirm) - { + if (callConfirm) { callConfirm->hide(); } GenericChatForm::hideEvent(event); } -OfflineMsgEngine *ChatForm::getOfflineMsgEngine() +OfflineMsgEngine* ChatForm::getOfflineMsgEngine() { return offlineEngine; } void ChatForm::SendMessageStr(QString msg) { - if (msg.isEmpty()) - { + if (msg.isEmpty()) { return; } bool isAction = msg.startsWith(ACTION_PREFIX, Qt::CaseInsensitive); - if (isAction) - { + if (isAction) { msg.remove(0, ACTION_PREFIX.length()); } QList splittedMsg = Core::splitMessage(msg, TOX_MAX_MESSAGE_LENGTH); QDateTime timestamp = QDateTime::currentDateTime(); - for (CString& c_msg : splittedMsg) - { + for (CString& c_msg : splittedMsg) { QString qt_msg = CString::toString(c_msg.data(), c_msg.size()); QString qt_msg_hist = qt_msg; - if (isAction) - { + if (isAction) { qt_msg_hist = ACTION_PREFIX + qt_msg; } @@ -1157,30 +1026,24 @@ void ChatForm::SendMessageStr(QString msg) Core* core = Core::getInstance(); uint32_t friendId = f->getFriendId(); - int rec = isAction ? core->sendAction(friendId, qt_msg) - : core->sendMessage(friendId, qt_msg); + int rec = isAction ? core->sendAction(friendId, qt_msg) : core->sendMessage(friendId, qt_msg); Profile* profile = Nexus::getProfile(); - if (profile->isHistoryEnabled()) - { + if (profile->isHistoryEnabled()) { auto* offMsgEngine = getOfflineMsgEngine(); QString selfPk = Core::getInstance()->getSelfId().toString(); QString pk = f->getPublicKey().toString(); QString name = Core::getInstance()->getUsername(); - profile->getHistory()->addNewMessage( - pk, qt_msg_hist, selfPk, timestamp, status, - name, [offMsgEngine, rec, ma](int64_t id) - { - offMsgEngine->registerReceipt(rec, id, ma); - }); - } - else - { + profile->getHistory()->addNewMessage(pk, qt_msg_hist, selfPk, timestamp, status, name, + [offMsgEngine, rec, ma](int64_t id) { + offMsgEngine->registerReceipt(rec, id, ma); + }); + } else { // TODO: Make faux-offline messaging work partially with the history disabled ma->markAsSent(QDateTime::currentDateTime()); } - msgEdit->setLastMessage(msg); //set last message only when sending it + msgEdit->setLastMessage(msg); // set last message only when sending it Widget::getInstance()->updateFriendActivity(f); } @@ -1196,8 +1059,7 @@ void ChatForm::retranslateUi() updateMuteMicButton(); updateMuteVolButton(); - if (netcam) - { + if (netcam) { netcam->setShowMessages(chatWidget->isVisible()); } } diff --git a/src/widget/form/chatform.h b/src/widget/form/chatform.h index 707ec0201..93a3791e7 100644 --- a/src/widget/form/chatform.h +++ b/src/widget/form/chatform.h @@ -20,10 +20,10 @@ #ifndef CHATFORM_H #define CHATFORM_H -#include -#include -#include #include +#include +#include +#include #include "genericchatform.h" #include "src/core/corestructs.h" @@ -82,18 +82,17 @@ private slots: void onMicMuteToggle(); void onVolMuteToggle(); - void onFileSendFailed(uint32_t friendId, const QString &fname); + void onFileSendFailed(uint32_t friendId, const QString& fname); void onFriendStatusChanged(quint32 friendId, Status status); void onFriendTypingChanged(quint32 friendId, bool isTyping); void onFriendNameChanged(const QString& name); - void onFriendMessageReceived(quint32 friendId, const QString& message, - bool isAction); + void onFriendMessageReceived(quint32 friendId, const QString& message, bool isAction); void onStatusMessage(const QString& message); void onReceiptReceived(quint32 friendId, int receipt); void onLoadHistory(); void onUpdateTime(); void onScreenshotClicked(); - void onScreenshotTaken(const QPixmap &pixmap); + void onScreenshotTaken(const QPixmap& pixmap); void doScreenshot(); void onCopyStatusMessage(); @@ -117,15 +116,14 @@ protected: void showEvent(QShowEvent* event) final override; private: - Friend* f; - CroppingLabel *statusMessageLabel; + CroppingLabel* statusMessageLabel; QMenu statusMessageMenu; - QLabel *callDuration; - QTimer *callDurationTimer; + QLabel* callDuration; + QTimer* callDurationTimer; QTimer typingTimer; QElapsedTimer timeElapsed; - OfflineMsgEngine *offlineEngine; + OfflineMsgEngine* offlineEngine; QAction* loadHistoryAction; QAction* copyStatusAction; diff --git a/src/widget/form/filesform.cpp b/src/widget/form/filesform.cpp index 99766b373..7a73a6c12 100644 --- a/src/widget/form/filesform.cpp +++ b/src/widget/form/filesform.cpp @@ -18,14 +18,15 @@ */ #include "filesform.h" -#include "src/widget/widget.h" -#include "src/widget/translator.h" #include "src/widget/contentlayout.h" +#include "src/widget/translator.h" +#include "src/widget/widget.h" #include #include FilesForm::FilesForm() - : QObject(), doneIcon(":/ui/fileTransferWidget/fileDone.svg") + : QObject() + , doneIcon(":/ui/fileTransferWidget/fileDone.svg") { head = new QWidget(); QFont bold; @@ -57,8 +58,7 @@ FilesForm::~FilesForm() bool FilesForm::isShown() const { - if (main.isVisible()) - { + if (main.isVisible()) { head->window()->windowHandle()->alert(0); return true; } @@ -93,14 +93,14 @@ void FilesForm::onFileUploadComplete(const QString& path) // whenever they're not saved anywhere custom, thanks to the hack) // I could do some digging around, but for now I'm tired and others already // might know it without me needing to dig, so... -void FilesForm::onFileActivated(QListWidgetItem *item) +void FilesForm::onFileActivated(QListWidgetItem* item) { Widget::confirmExecutableOpen(QFileInfo(item->data(Qt::UserRole).toString())); } void FilesForm::retranslateUi() { - headLabel.setText(tr("Transferred Files","\"Headline\" of the window")); + headLabel.setText(tr("Transferred Files", "\"Headline\" of the window")); main.setTabText(0, tr("Downloads")); main.setTabText(1, tr("Uploads")); } diff --git a/src/widget/form/filesform.h b/src/widget/form/filesform.h index c90f43255..9abee5173 100644 --- a/src/widget/form/filesform.h +++ b/src/widget/form/filesform.h @@ -20,10 +20,10 @@ #ifndef FILESFORM_H #define FILESFORM_H -#include -#include -#include #include +#include +#include +#include #include class ContentLayout; @@ -56,7 +56,7 @@ private: QLabel headLabel; QVBoxLayout headLayout; QTabWidget main; - QListWidget* sent, * recvd; + QListWidget *sent, *recvd; }; #endif // FILESFORM_H diff --git a/src/widget/form/genericchatform.cpp b/src/widget/form/genericchatform.cpp index 141a78cf1..dc96ae14f 100644 --- a/src/widget/form/genericchatform.cpp +++ b/src/widget/form/genericchatform.cpp @@ -19,6 +19,7 @@ #include "genericchatform.h" +#include #include #include #include @@ -26,7 +27,6 @@ #include #include #include -#include #include #include "src/chatlog/chatlog.h" @@ -61,10 +61,10 @@ * (excluded) */ -GenericChatForm::GenericChatForm(QWidget *parent) - : QWidget(parent, Qt::Window) - , audioInputFlag(false) - , audioOutputFlag(false) +GenericChatForm::GenericChatForm(QWidget* parent) + : QWidget(parent, Qt::Window) + , audioInputFlag(false) + , audioOutputFlag(false) { curRow = 0; headWidget = new QWidget(); @@ -75,26 +75,22 @@ GenericChatForm::GenericChatForm(QWidget *parent) nameLabel->setEditable(true); nameLabel->setTextFormat(Qt::PlainText); - avatar = new MaskablePixmapWidget(this, QSize(40,40), ":/img/avatar_mask.svg"); - QHBoxLayout *mainFootLayout = new QHBoxLayout(), - *headLayout = new QHBoxLayout(); + avatar = new MaskablePixmapWidget(this, QSize(40, 40), ":/img/avatar_mask.svg"); + QHBoxLayout *mainFootLayout = new QHBoxLayout(), *headLayout = new QHBoxLayout(); - QVBoxLayout *mainLayout = new QVBoxLayout(), - *footButtonsSmall = new QVBoxLayout(), + QVBoxLayout *mainLayout = new QVBoxLayout(), *footButtonsSmall = new QVBoxLayout(), *micButtonsLayout = new QVBoxLayout(); - headTextLayout = new QVBoxLayout(); + headTextLayout = new QVBoxLayout(); - QGridLayout *buttonsLayout = new QGridLayout(); + QGridLayout* buttonsLayout = new QGridLayout(); chatWidget = new ChatLog(this); chatWidget->setBusyNotification(ChatMessage::createBusyNotification()); // settings const Settings& s = Settings::getInstance(); - connect(&s, &Settings::emojiFontPointSizeChanged, - chatWidget, &ChatLog::forceRelayout); - connect(&s, &Settings::chatMessageFontChanged, - this, &GenericChatForm::onChatMessageFontChanged); + connect(&s, &Settings::emojiFontPointSizeChanged, chatWidget, &ChatLog::forceRelayout); + connect(&s, &Settings::chatMessageFontChanged, this, &GenericChatForm::onChatMessageFontChanged); msgEdit = new ChatTextEdit(); @@ -105,10 +101,10 @@ GenericChatForm::GenericChatForm(QWidget *parent) fileButton = new QPushButton(); screenshotButton = new QPushButton; callButton = new QPushButton(); - callButton->setFixedSize(50,40); + callButton->setFixedSize(50, 40); videoButton = new QPushButton(); - videoButton->setFixedSize(50,40); + videoButton->setFixedSize(50, 40); volButton = new QToolButton(); volButton->setFixedSize(22, 18); @@ -119,7 +115,7 @@ GenericChatForm::GenericChatForm(QWidget *parent) // and call here to set tooltips. fileFlyout = new FlyoutOverlayWidget; - QHBoxLayout *fileLayout = new QHBoxLayout(fileFlyout); + QHBoxLayout* fileLayout = new QHBoxLayout(fileFlyout); fileLayout->addWidget(screenshotButton); fileLayout->setContentsMargins(0, 0, 0, 0); @@ -128,13 +124,14 @@ GenericChatForm::GenericChatForm(QWidget *parent) fileLayout->setMargin(0); msgEdit->setStyleSheet(Style::getStylesheet(":/ui/msgEdit/msgEdit.css") - + fontToCss(s.getChatMessageFont(), "QTextEdit")); + + fontToCss(s.getChatMessageFont(), "QTextEdit")); msgEdit->setFixedHeight(50); msgEdit->setFrameStyle(QFrame::NoFrame); sendButton->setStyleSheet(Style::getStylesheet(":/ui/sendButton/sendButton.css")); fileButton->setStyleSheet(Style::getStylesheet(":/ui/fileButton/fileButton.css")); - screenshotButton->setStyleSheet(Style::getStylesheet(":/ui/screenshotButton/screenshotButton.css")); + screenshotButton->setStyleSheet( + Style::getStylesheet(":/ui/screenshotButton/screenshotButton.css")); emoteButton->setStyleSheet(Style::getStylesheet(":/ui/emoteButton/emoteButton.css")); callButton->setObjectName("green"); @@ -195,8 +192,8 @@ GenericChatForm::GenericChatForm(QWidget *parent) headWidget->setLayout(headLayout); - //Fix for incorrect layouts on OS X as per - //https://bugreports.qt-project.org/browse/QTBUG-14591 + // Fix for incorrect layouts on OS X as per + // https://bugreports.qt-project.org/browse/QTBUG-14591 sendButton->setAttribute(Qt::WA_LayoutUsesWidgetRect); fileButton->setAttribute(Qt::WA_LayoutUsesWidgetRect); screenshotButton->setAttribute(Qt::WA_LayoutUsesWidgetRect); @@ -208,23 +205,20 @@ GenericChatForm::GenericChatForm(QWidget *parent) menu.addActions(chatWidget->actions()); menu.addSeparator(); - saveChatAction = menu.addAction(QIcon::fromTheme("document-save"), - QString(), this, SLOT(onSaveLogClicked())); - clearAction = menu.addAction(QIcon::fromTheme("edit-clear"), - QString(), this, SLOT(clearChatArea(bool))); + saveChatAction = + menu.addAction(QIcon::fromTheme("document-save"), QString(), this, SLOT(onSaveLogClicked())); + clearAction = + menu.addAction(QIcon::fromTheme("edit-clear"), QString(), this, SLOT(clearChatArea(bool))); - quoteAction = menu.addAction(QIcon(), - QString(), this, SLOT(quoteSelectedText())); + quoteAction = menu.addAction(QIcon(), QString(), this, SLOT(quoteSelectedText())); - copyLinkAction = menu.addAction(QIcon(), - QString(), this, SLOT(copyLink())); + copyLinkAction = menu.addAction(QIcon(), QString(), this, SLOT(copyLink())); menu.addSeparator(); - connect(emoteButton, &QPushButton::clicked, - this, &GenericChatForm::onEmoteButtonClicked); - connect(chatWidget, &ChatLog::customContextMenuRequested, - this, &GenericChatForm::onChatContextMenuRequested); + connect(emoteButton, &QPushButton::clicked, this, &GenericChatForm::onEmoteButtonClicked); + connect(chatWidget, &ChatLog::customContextMenuRequested, this, + &GenericChatForm::onChatContextMenuRequested); new QShortcut(Qt::CTRL + Qt::SHIFT + Qt::Key_L, this, SLOT(clearChatArea())); new QShortcut(Qt::ALT + Qt::Key_Q, this, SLOT(quoteSelectedText())); @@ -275,7 +269,7 @@ bool GenericChatForm::isEmpty() return chatWidget->isEmpty(); } -ChatLog *GenericChatForm::getChatLog() const +ChatLog* GenericChatForm::getChatLog() const { return chatWidget; } @@ -284,8 +278,7 @@ QDate GenericChatForm::getLatestDate() const { ChatLine::Ptr chatLine = chatWidget->getLatestLine(); - if (chatLine) - { + if (chatLine) { Timestamp* timestamp = qobject_cast(chatLine->getContent(2)); if (timestamp) @@ -297,10 +290,11 @@ QDate GenericChatForm::getLatestDate() const return QDate(); } -void GenericChatForm::setName(const QString &newName) +void GenericChatForm::setName(const QString& newName) { nameLabel->setText(newName); - nameLabel->setToolTip(Qt::convertFromPlainText(newName, Qt::WhiteSpaceNormal)); // for overlength names + nameLabel->setToolTip( + Qt::convertFromPlainText(newName, Qt::WhiteSpaceNormal)); // for overlength names } void GenericChatForm::show(ContentLayout* contentLayout) @@ -311,7 +305,7 @@ void GenericChatForm::show(ContentLayout* contentLayout) QWidget::show(); } -void GenericChatForm::showEvent(QShowEvent *) +void GenericChatForm::showEvent(QShowEvent*) { msgEdit->setFocus(); } @@ -319,11 +313,10 @@ void GenericChatForm::showEvent(QShowEvent *) bool GenericChatForm::event(QEvent* e) { // If the user accidentally starts typing outside of the msgEdit, focus it automatically - if (e->type() == QEvent::KeyRelease && !msgEdit->hasFocus()) - { + if (e->type() == QEvent::KeyRelease && !msgEdit->hasFocus()) { QKeyEvent* ke = static_cast(e); if ((ke->modifiers() == Qt::NoModifier || ke->modifiers() == Qt::ShiftModifier) - && !ke->text().isEmpty()) + && !ke->text().isEmpty()) msgEdit->setFocus(); } return QWidget::event(e); @@ -337,12 +330,10 @@ void GenericChatForm::onChatContextMenuRequested(QPoint pos) // If we right-clicked on a link, give the option to copy it bool clickedOnLink = false; Text* clickedText = qobject_cast(chatWidget->getContentFromGlobalPos(pos)); - if (clickedText) - { + if (clickedText) { QPointF scenePos = chatWidget->mapToScene(chatWidget->mapFromGlobal(pos)); QString linkTarget = clickedText->getLinkAt(scenePos); - if (!linkTarget.isEmpty()) - { + if (!linkTarget.isEmpty()) { clickedOnLink = true; copyLinkAction->setData(linkTarget); } @@ -352,31 +343,30 @@ void GenericChatForm::onChatContextMenuRequested(QPoint pos) menu.exec(pos); } -ChatMessage::Ptr GenericChatForm::addMessage(const ToxPk& author, const QString &message, bool isAction, - const QDateTime &datetime, bool isSent) +ChatMessage::Ptr GenericChatForm::addMessage(const ToxPk& author, const QString& message, + bool isAction, const QDateTime& datetime, bool isSent) { const Core* core = Core::getInstance(); bool authorIsActiveProfile = author == core->getSelfId().getPublicKey(); QString authorStr = authorIsActiveProfile ? core->getUsername() : resolveToxId(author); - if (getLatestDate() != QDate::currentDate()) - { + if (getLatestDate() != QDate::currentDate()) { const Settings& s = Settings::getInstance(); QString dateText = QDate::currentDate().toString(s.getDateFormat()); addSystemInfoMessage(dateText, ChatMessage::INFO, QDateTime()); } ChatMessage::Ptr msg; - if (isAction) - { - msg = ChatMessage::createChatMessage(authorStr, message, ChatMessage::ACTION, authorIsActiveProfile); + if (isAction) { + msg = ChatMessage::createChatMessage(authorStr, message, ChatMessage::ACTION, + authorIsActiveProfile); previousId = ToxPk(); - } - else - { - msg = ChatMessage::createChatMessage(authorStr, message, ChatMessage::NORMAL, authorIsActiveProfile); - if ( (author == previousId) && (prevMsgDateTime.secsTo(QDateTime::currentDateTime()) < getChatLog()->repNameAfter) ) + } else { + msg = ChatMessage::createChatMessage(authorStr, message, ChatMessage::NORMAL, + authorIsActiveProfile); + if ((author == previousId) + && (prevMsgDateTime.secsTo(QDateTime::currentDateTime()) < getChatLog()->repNameAfter)) msg->hideSender(); previousId = author; @@ -391,19 +381,23 @@ ChatMessage::Ptr GenericChatForm::addMessage(const ToxPk& author, const QString return msg; } -ChatMessage::Ptr GenericChatForm::addSelfMessage(const QString &message, bool isAction, const QDateTime &datetime, bool isSent) +ChatMessage::Ptr GenericChatForm::addSelfMessage(const QString& message, bool isAction, + const QDateTime& datetime, bool isSent) { - return addMessage(Core::getInstance()->getSelfId().getPublicKey(), message, isAction, datetime, isSent); + return addMessage(Core::getInstance()->getSelfId().getPublicKey(), message, isAction, datetime, + isSent); } -void GenericChatForm::addAlertMessage(const ToxPk &author, QString message, QDateTime datetime) +void GenericChatForm::addAlertMessage(const ToxPk& author, QString message, QDateTime datetime) { QString authorStr = resolveToxId(author); bool isSelf = author == Core::getInstance()->getSelfId().getPublicKey(); - ChatMessage::Ptr msg = ChatMessage::createChatMessage(authorStr, message, ChatMessage::ALERT, isSelf, datetime); + ChatMessage::Ptr msg = + ChatMessage::createChatMessage(authorStr, message, ChatMessage::ALERT, isSelf, datetime); insertChatMessage(msg); - if ((author == previousId) && (prevMsgDateTime.secsTo(QDateTime::currentDateTime()) < getChatLog()->repNameAfter)) + if ((author == previousId) + && (prevMsgDateTime.secsTo(QDateTime::currentDateTime()) < getChatLog()->repNameAfter)) msg->hideSender(); previousId = author; @@ -421,9 +415,9 @@ void GenericChatForm::onEmoteButtonClicked() widget.installEventFilter(this); QWidget* sender = qobject_cast(QObject::sender()); - if (sender) - { - QPoint pos = -QPoint(widget.sizeHint().width() / 2, widget.sizeHint().height()) - QPoint(0, 10); + if (sender) { + QPoint pos = + -QPoint(widget.sizeHint().width() / 2, widget.sizeHint().height()) - QPoint(0, 10); widget.exec(sender->mapToGlobal(pos)); } } @@ -450,8 +444,7 @@ void GenericChatForm::onSaveLogClicked() QString plainText; auto lines = chatWidget->getLines(); - for (ChatLine::Ptr l : lines) - { + for (ChatLine::Ptr l : lines) { Timestamp* rightCol = qobject_cast(l->getContent(2)); if (!rightCol) @@ -481,16 +474,18 @@ void GenericChatForm::focusInput() msgEdit->setFocus(); } -void GenericChatForm::onChatMessageFontChanged(const QFont& font) { +void GenericChatForm::onChatMessageFontChanged(const QFont& font) +{ // chat log chatWidget->fontChanged(font); chatWidget->forceRelayout(); // message editor msgEdit->setStyleSheet(Style::getStylesheet(":/ui/msgEdit/msgEdit.css") - + fontToCss(font, "QTextEdit")); + + fontToCss(font, "QTextEdit")); } -void GenericChatForm::addSystemInfoMessage(const QString &message, ChatMessage::SystemMessageType type, const QDateTime &datetime) +void GenericChatForm::addSystemInfoMessage(const QString& message, ChatMessage::SystemMessageType type, + const QDateTime& datetime) { previousId = ToxPk(); insertChatMessage(ChatMessage::createChatInfoMessage(message, type, datetime)); @@ -509,7 +504,7 @@ void GenericChatForm::clearChatArea(bool notinform) if (!notinform) addSystemInfoMessage(tr("Cleared"), ChatMessage::INFO, QDateTime::currentDateTime()); - earliestMessage = QDateTime(); //null + earliestMessage = QDateTime(); // null historyBaselineDate = QDateTime::currentDateTime(); emit chatAreaCleared(); @@ -520,14 +515,13 @@ void GenericChatForm::onSelectAllClicked() chatWidget->selectAll(); } -QString GenericChatForm::resolveToxId(const ToxPk &id) +QString GenericChatForm::resolveToxId(const ToxPk& id) { Friend* f = FriendList::findFriend(id); if (f) return f->getDisplayedName(); - for (Group *it : GroupList::getAllGroups()) - { + for (Group* it : GroupList::getAllGroups()) { QString res = it->resolveToxId(id); if (res.size()) return res; @@ -557,8 +551,7 @@ void GenericChatForm::resizeEvent(QResizeEvent* event) bool GenericChatForm::eventFilter(QObject* object, QEvent* event) { EmoticonsWidget* ev = qobject_cast(object); - if (ev && event->type() == QEvent::KeyPress) - { + if (ev && event->type() == QEvent::KeyPress) { QKeyEvent* key = static_cast(event); msgEdit->sendKeyEvent(key); msgEdit->setFocus(); @@ -571,14 +564,12 @@ bool GenericChatForm::eventFilter(QObject* object, QEvent* event) if (!qobject_cast(object)->isEnabled()) return false; - switch(event->type()) - { + switch (event->type()) { case QEvent::Enter: showFileMenu(); break; - case QEvent::Leave: - { + case QEvent::Leave: { QPoint flyPos = fileFlyout->mapToGlobal(QPoint()); QSize flySize = fileFlyout->size(); @@ -612,8 +603,7 @@ void GenericChatForm::onSplitterMoved(int, int) void GenericChatForm::onShowMessagesClicked() { - if (netcam) - { + if (netcam) { if (bodySplitter->sizes()[1] == 0) bodySplitter->setSizes({1, 1}); else @@ -687,10 +677,10 @@ QString GenericChatForm::fontToCss(const QFont& font, const char* name) .arg(name) .arg(font.family()) .arg(font.pixelSize()) - .arg(font.style() == QFont::StyleNormal ? "normal" - : font.style() == QFont::StyleItalic ? "italic" - : "bold") - .arg(font.weight()*10); // QFont weight is 0..100, but CSS font-weight is 0..1000 + .arg(font.style() == QFont::StyleNormal ? "normal" : font.style() == QFont::StyleItalic + ? "italic" + : "bold") + .arg(font.weight() * 10); // QFont weight is 0..100, but CSS font-weight is 0..1000 } void GenericChatForm::showNetcam() @@ -698,8 +688,8 @@ void GenericChatForm::showNetcam() if (!netcam) netcam = createNetcam(); - connect(netcam, &GenericNetCamView::showMessageClicked, - this, &GenericChatForm::onShowMessagesClicked); + connect(netcam, &GenericNetCamView::showMessageClicked, this, + &GenericChatForm::onShowMessagesClicked); bodySplitter->insertWidget(0, netcam); bodySplitter->setCollapsible(0, false); diff --git a/src/widget/form/genericchatform.h b/src/widget/form/genericchatform.h index 0613fc80f..de98dc895 100644 --- a/src/widget/form/genericchatform.h +++ b/src/widget/form/genericchatform.h @@ -25,8 +25,8 @@ #include #include -#include "src/core/corestructs.h" #include "src/chatlog/chatmessage.h" +#include "src/core/corestructs.h" #include "src/core/toxid.h" /** @@ -51,7 +51,7 @@ class GenericNetCamView; class QToolButton; namespace Ui { - class MainWindow; +class MainWindow; } class GenericChatForm : public QWidget @@ -61,14 +61,19 @@ public: explicit GenericChatForm(QWidget* parent = 0); ~GenericChatForm(); - void setName(const QString &newName); - virtual void show() final{} + void setName(const QString& newName); + virtual void show() final + { + } virtual void show(ContentLayout* contentLayout); - ChatMessage::Ptr addMessage(const ToxPk& author, const QString &message, bool isAction, const QDateTime &datetime, bool isSent); - ChatMessage::Ptr addSelfMessage(const QString &message, bool isAction, const QDateTime &datetime, bool isSent); + ChatMessage::Ptr addMessage(const ToxPk& author, const QString& message, bool isAction, + const QDateTime& datetime, bool isSent); + ChatMessage::Ptr addSelfMessage(const QString& message, bool isAction, + const QDateTime& datetime, bool isSent); - void addSystemInfoMessage(const QString &message, ChatMessage::SystemMessageType type, const QDateTime &datetime); + void addSystemInfoMessage(const QString& message, ChatMessage::SystemMessageType type, + const QDateTime& datetime); void addAlertMessage(const ToxPk& author, QString message, QDateTime datetime); bool isEmpty(); @@ -109,33 +114,33 @@ protected: void showNetcam(); void hideNetcam(); virtual GenericNetCamView* createNetcam() = 0; - QString resolveToxId(const ToxPk &id); + QString resolveToxId(const ToxPk& id); virtual void insertChatMessage(ChatMessage::Ptr msg); void adjustFileMenuPosition(); virtual void hideEvent(QHideEvent* event) override; - virtual void showEvent(QShowEvent *) override; - virtual bool event(QEvent *) final override; + virtual void showEvent(QShowEvent*) override; + virtual bool event(QEvent*) final override; virtual void resizeEvent(QResizeEvent* event) final override; virtual bool eventFilter(QObject* object, QEvent* event) final override; protected: - QAction* saveChatAction, *clearAction, *quoteAction, *copyLinkAction; + QAction *saveChatAction, *clearAction, *quoteAction, *copyLinkAction; ToxPk previousId; QDateTime prevMsgDateTime; - Widget *parent; + Widget* parent; QMenu menu; int curRow; - CroppingLabel *nameLabel; - MaskablePixmapWidget *avatar; - QWidget *headWidget; - QPushButton* fileButton, *screenshotButton, *emoteButton, *callButton; + CroppingLabel* nameLabel; + MaskablePixmapWidget* avatar; + QWidget* headWidget; + QPushButton *fileButton, *screenshotButton, *emoteButton, *callButton; QPushButton* videoButton; QToolButton *volButton, *micButton; - FlyoutOverlayWidget *fileFlyout; - QVBoxLayout *headTextLayout; - ChatTextEdit *msgEdit; - QPushButton *sendButton; - ChatLog *chatWidget; + FlyoutOverlayWidget* fileFlyout; + QVBoxLayout* headTextLayout; + ChatTextEdit* msgEdit; + QPushButton* sendButton; + ChatLog* chatWidget; QDateTime earliestMessage; QDateTime historyBaselineDate = QDateTime::currentDateTime(); diff --git a/src/widget/form/groupchatform.cpp b/src/widget/form/groupchatform.cpp index 0d065ff52..af9f40755 100644 --- a/src/widget/form/groupchatform.cpp +++ b/src/widget/form/groupchatform.cpp @@ -25,19 +25,19 @@ #include #include "tabcompleter.h" -#include "src/group.h" -#include "src/friend.h" -#include "src/friendlist.h" -#include "src/widget/groupwidget.h" -#include "src/widget/tool/croppinglabel.h" -#include "src/widget/maskablepixmapwidget.h" #include "src/core/core.h" #include "src/core/coreav.h" -#include "src/widget/style.h" -#include "src/widget/flowlayout.h" -#include "src/widget/translator.h" -#include "src/widget/form/chatform.h" +#include "src/friend.h" +#include "src/friendlist.h" +#include "src/group.h" #include "src/video/groupnetcamview.h" +#include "src/widget/flowlayout.h" +#include "src/widget/form/chatform.h" +#include "src/widget/groupwidget.h" +#include "src/widget/maskablepixmapwidget.h" +#include "src/widget/style.h" +#include "src/widget/tool/croppinglabel.h" +#include "src/widget/translator.h" /** * @var QList GroupChatForm::peerLabels @@ -58,13 +58,10 @@ GroupChatForm::GroupChatForm(Group* chatGroup) tabber = new TabCompleter(msgEdit, group); fileButton->setEnabled(false); - if (group->isAvGroupchat()) - { + if (group->isAvGroupchat()) { videoButton->setEnabled(false); videoButton->setObjectName("grey"); - } - else - { + } else { videoButton->setVisible(false); callButton->setVisible(false); volButton->setVisible(false); @@ -81,15 +78,13 @@ GroupChatForm::GroupChatForm(Group* chatGroup) msgEdit->setObjectName("group"); - namesListLayout = new FlowLayout(0,5,0); + namesListLayout = new FlowLayout(0, 5, 0); QStringList names(group->getPeerList()); - for (QString& name : names) - { - QLabel *l = new QLabel(); + for (QString& name : names) { + QLabel* l = new QLabel(); QString tooltip = correctNames(name); - if (tooltip.isNull()) - { + if (tooltip.isNull()) { l->setToolTip(tooltip); } l->setText(name); @@ -111,10 +106,8 @@ GroupChatForm::GroupChatForm(Group* chatGroup) connect(callButton, &QPushButton::clicked, this, &GroupChatForm::onCallClicked); connect(micButton, SIGNAL(clicked()), this, SLOT(onMicMuteToggle())); connect(volButton, SIGNAL(clicked()), this, SLOT(onVolMuteToggle())); - connect(nameLabel, &CroppingLabel::editFinished, this, [=](const QString& newName) - { - if (!newName.isEmpty()) - { + connect(nameLabel, &CroppingLabel::editFinished, this, [=](const QString& newName) { + if (!newName.isEmpty()) { nameLabel->setText(newName); emit groupTitleChanged(group->getGroupId(), newName.left(128)); } @@ -129,15 +122,12 @@ QString GroupChatForm::correctNames(QString& name) { int pos = name.indexOf(QRegExp("\n|\r\n|\r")); int len = name.length(); - if ( (pos < len) && (pos !=-1) ) - { + if ((pos < len) && (pos != -1)) { QString tooltip = name; - name.remove( pos, len-pos ); + name.remove(pos, len - pos); name.append("..."); return tooltip; - } - else - { + } else { return QString(); } } @@ -156,22 +146,17 @@ void GroupChatForm::onSendTriggered() msgEdit->setLastMessage(msg); msgEdit->clear(); - if (group->getPeersCount() != 1) - { - if (msg.startsWith(ChatForm::ACTION_PREFIX, Qt::CaseInsensitive)) - { + if (group->getPeersCount() != 1) { + if (msg.startsWith(ChatForm::ACTION_PREFIX, Qt::CaseInsensitive)) { msg.remove(0, ChatForm::ACTION_PREFIX.length()); emit sendAction(group->getGroupId(), msg); - } - else - { + } else { emit sendMessage(group->getGroupId(), msg); } - } - else - { + } else { if (msg.startsWith(ChatForm::ACTION_PREFIX, Qt::CaseInsensitive)) - addSelfMessage(msg.mid(ChatForm::ACTION_PREFIX.length()), true, QDateTime::currentDateTime(), true); + addSelfMessage(msg.mid(ChatForm::ACTION_PREFIX.length()), true, + QDateTime::currentDateTime(), true); else addSelfMessage(msg, false, QDateTime::currentDateTime(), true); } @@ -185,9 +170,8 @@ void GroupChatForm::onUserListChanged() else nusersLabel->setText(tr("%1 users in chat", "Number of users in chat").arg(peersCount)); - QLayoutItem *child; - while ((child = namesListLayout->takeAt(0))) - { + QLayoutItem* child; + while ((child = namesListLayout->takeAt(0))) { child->widget()->hide(); delete child->widget(); delete child; @@ -200,8 +184,7 @@ void GroupChatForm::onUserListChanged() // first traverse in peer number order, storing the QLabels as necessary QStringList names = group->getPeerList(); unsigned nNames = names.size(); - for (unsigned i=0; i(netcam)->clearPeers(); // now alphabetize and add to layout - qSort(nickLabelList.begin(), nickLabelList.end(), [](QLabel *a, QLabel *b){return a->text().toLower() < b->text().toLower();}); - for (unsigned i=0; itext().toLower() < b->text().toLower(); }); + for (unsigned i = 0; i < nNames; ++i) { + QLabel* label = nickLabelList.at(i); if (i != nNames - 1) label->setText(label->text() + ", "); @@ -230,19 +213,15 @@ void GroupChatForm::onUserListChanged() } // Enable or disable call button - if (peersCount > 1 && group->isAvGroupchat()) - { + if (peersCount > 1 && group->isAvGroupchat()) { // don't set button to green if call running - if (!inCall) - { + if (!inCall) { callButton->setEnabled(true); callButton->setObjectName("green"); callButton->style()->polish(callButton); callButton->setToolTip(tr("Start audio call")); } - } - else - { + } else { callButton->setEnabled(false); callButton->setObjectName("grey"); callButton->style()->polish(callButton); @@ -255,12 +234,10 @@ void GroupChatForm::onUserListChanged() void GroupChatForm::peerAudioPlaying(int peer) { peerLabels[peer]->setStyleSheet("QLabel {color : red;}"); - if (!peerAudioTimers[peer]) - { + if (!peerAudioTimers[peer]) { peerAudioTimers[peer] = new QTimer(this); peerAudioTimers[peer]->setSingleShot(true); - connect(peerAudioTimers[peer], &QTimer::timeout, [this, peer] - { + connect(peerAudioTimers[peer], &QTimer::timeout, [this, peer] { if (netcam) static_cast(netcam)->removePeer(peer); @@ -272,8 +249,7 @@ void GroupChatForm::peerAudioPlaying(int peer) peerAudioTimers[peer] = nullptr; }); - if (netcam) - { + if (netcam) { static_cast(netcam)->removePeer(peer); static_cast(netcam)->addPeer(peer, group->getPeerList()[peer]); } @@ -281,7 +257,7 @@ void GroupChatForm::peerAudioPlaying(int peer) peerAudioTimers[peer]->start(500); } -void GroupChatForm::dragEnterEvent(QDragEnterEvent *ev) +void GroupChatForm::dragEnterEvent(QDragEnterEvent* ev) { ToxId toxId = ToxId(ev->mimeData()->text()); Friend* frnd = FriendList::findFriend(toxId.getPublicKey()); @@ -289,7 +265,7 @@ void GroupChatForm::dragEnterEvent(QDragEnterEvent *ev) ev->acceptProposedAction(); } -void GroupChatForm::dropEvent(QDropEvent *ev) +void GroupChatForm::dropEvent(QDropEvent* ev) { ToxId toxId = ToxId(ev->mimeData()->text()); Friend* frnd = FriendList::findFriend(toxId.getPublicKey()); @@ -305,17 +281,13 @@ void GroupChatForm::dropEvent(QDropEvent *ev) void GroupChatForm::onMicMuteToggle() { - if (audioInputFlag) - { + if (audioInputFlag) { CoreAV* av = Core::getInstance()->getAv(); - if (micButton->objectName() == "red") - { + if (micButton->objectName() == "red") { av->muteCallInput(group, false); micButton->setObjectName("green"); micButton->setToolTip(tr("Mute microphone")); - } - else - { + } else { av->muteCallInput(group, true); micButton->setObjectName("red"); micButton->setToolTip(tr("Unmute microphone")); @@ -327,17 +299,13 @@ void GroupChatForm::onMicMuteToggle() void GroupChatForm::onVolMuteToggle() { - if (audioOutputFlag) - { + if (audioOutputFlag) { CoreAV* av = Core::getInstance()->getAv(); - if (volButton->objectName() == "red") - { + if (volButton->objectName() == "red") { av->muteCallOutput(group, false); volButton->setObjectName("green"); volButton->setToolTip(tr("Mute call")); - } - else - { + } else { av->muteCallOutput(group, true); volButton->setObjectName("red"); volButton->setToolTip(tr("Unmute call")); @@ -349,8 +317,7 @@ void GroupChatForm::onVolMuteToggle() void GroupChatForm::onCallClicked() { - if (!inCall) - { + if (!inCall) { Core::getInstance()->getAv()->joinGroupCall(group->getGroupId()); audioInputFlag = true; audioOutputFlag = true; @@ -365,9 +332,7 @@ void GroupChatForm::onCallClicked() volButton->setToolTip(tr("Mute call")); inCall = true; showNetcam(); - } - else - { + } else { Core::getInstance()->getAv()->leaveGroupCall(group->getGroupId()); audioInputFlag = false; audioOutputFlag = false; @@ -385,13 +350,12 @@ void GroupChatForm::onCallClicked() } } -GenericNetCamView *GroupChatForm::createNetcam() +GenericNetCamView* GroupChatForm::createNetcam() { GroupNetCamView* view = new GroupNetCamView(group->getGroupId(), this); QStringList names = group->getPeerList(); - for (int i = 0; iisSelfPeerNumber(i)) static_cast(view)->addPeer(i, names[i]); } @@ -402,11 +366,9 @@ GenericNetCamView *GroupChatForm::createNetcam() void GroupChatForm::keyPressEvent(QKeyEvent* ev) { // Push to talk (CTRL+P) - if (ev->key() == Qt::Key_P && (ev->modifiers() & Qt::ControlModifier) && inCall) - { + if (ev->key() == Qt::Key_P && (ev->modifiers() & Qt::ControlModifier) && inCall) { CoreAV* av = Core::getInstance()->getAv(); - if (!av->isGroupCallInputMuted(group)) - { + if (!av->isGroupCallInputMuted(group)) { av->muteCallInput(group, false); micButton->setObjectName("green"); micButton->style()->polish(micButton); @@ -421,11 +383,9 @@ void GroupChatForm::keyPressEvent(QKeyEvent* ev) void GroupChatForm::keyReleaseEvent(QKeyEvent* ev) { // Push to talk (CTRL+P) - if (ev->key() == Qt::Key_P && (ev->modifiers() & Qt::ControlModifier) && inCall) - { + if (ev->key() == Qt::Key_P && (ev->modifiers() & Qt::ControlModifier) && inCall) { CoreAV* av = Core::getInstance()->getAv(); - if (av->isGroupCallInputMuted(group)) - { + if (av->isGroupCallInputMuted(group)) { av->muteCallInput(group, true); micButton->setObjectName("red"); micButton->style()->polish(micButton); diff --git a/src/widget/form/groupchatform.h b/src/widget/form/groupchatform.h index 39c2a17c3..22e0c434e 100644 --- a/src/widget/form/groupchatform.h +++ b/src/widget/form/groupchatform.h @@ -23,7 +23,9 @@ #include "genericchatform.h" #include -namespace Ui {class MainWindow;} +namespace Ui { +class MainWindow; +} class Group; class TabCompleter; class FlowLayout; @@ -68,7 +70,7 @@ private: QList peerLabels; QMap peerAudioTimers; FlowLayout* namesListLayout; - QLabel *nusersLabel; + QLabel* nusersLabel; TabCompleter* tabber; bool inCall; QString correctNames(QString& name); diff --git a/src/widget/form/groupinviteform.cpp b/src/widget/form/groupinviteform.cpp index 817f5bdec..a3094c5db 100644 --- a/src/widget/form/groupinviteform.cpp +++ b/src/widget/form/groupinviteform.cpp @@ -19,21 +19,21 @@ #include "groupinviteform.h" -#include "src/widget/form/groupinvitewidget.h" +#include "ui_mainwindow.h" #include "src/core/core.h" #include "src/nexus.h" #include "src/persistence/settings.h" #include "src/widget/contentlayout.h" +#include "src/widget/form/groupinvitewidget.h" #include "src/widget/translator.h" -#include "ui_mainwindow.h" -#include #include #include #include #include #include #include +#include #include #include @@ -53,10 +53,8 @@ GroupInviteForm::GroupInviteForm() , headWidget(new QWidget(this)) { QVBoxLayout* layout = new QVBoxLayout(this); - connect(createButton, &QPushButton::clicked, [this]() - { - emit groupCreate(TOX_CONFERENCE_TYPE_AV); - }); + connect(createButton, &QPushButton::clicked, + [this]() { emit groupCreate(TOX_CONFERENCE_TYPE_AV); }); QWidget* innerWidget = new QWidget(scroll); innerWidget->setLayout(new QVBoxLayout()); @@ -93,8 +91,7 @@ GroupInviteForm::~GroupInviteForm() bool GroupInviteForm::isShown() const { bool result = isVisible(); - if (result) - { + if (result) { headWidget->window()->windowHandle()->alert(0); } return result; @@ -123,17 +120,13 @@ void GroupInviteForm::addGroupInvite(int32_t friendId, uint8_t type, QByteArray GroupInviteWidget* widget = new GroupInviteWidget(this, GroupInvite(friendId, type, invite)); scroll->widget()->layout()->addWidget(widget); invites.append(widget); - connect(widget, &GroupInviteWidget::accepted, - [this] (const GroupInvite& inviteInfo) { + connect(widget, &GroupInviteWidget::accepted, [this](const GroupInvite& inviteInfo) { deleteInviteWidget(inviteInfo); - emit groupInviteAccepted(inviteInfo.getFriendId(), - inviteInfo.getType(), + emit groupInviteAccepted(inviteInfo.getFriendId(), inviteInfo.getType(), inviteInfo.getInvite()); }); connect(widget, &GroupInviteWidget::rejected, - [this] (const GroupInvite& inviteInfo) { - deleteInviteWidget(inviteInfo); - }); + [this](const GroupInvite& inviteInfo) { deleteInviteWidget(inviteInfo); }); if (isVisible()) { emit groupInvitesSeen(); } @@ -149,12 +142,12 @@ void GroupInviteForm::showEvent(QShowEvent* event) * @brief Deletes accepted/declined group invite widget * @param inviteInfo Invite information of accepted/declined widget */ -void GroupInviteForm::deleteInviteWidget(const GroupInvite &inviteInfo) +void GroupInviteForm::deleteInviteWidget(const GroupInvite& inviteInfo) { - auto deletingWidget = std::find_if(invites.begin(), invites.end(), - [=] (const GroupInviteWidget* widget) { - return inviteInfo == widget->getInviteInfo(); - }); + auto deletingWidget = + std::find_if(invites.begin(), invites.end(), [=](const GroupInviteWidget* widget) { + return inviteInfo == widget->getInviteInfo(); + }); (*deletingWidget)->deleteLater(); scroll->widget()->layout()->removeWidget(*deletingWidget); invites.erase(deletingWidget); @@ -163,13 +156,11 @@ void GroupInviteForm::deleteInviteWidget(const GroupInvite &inviteInfo) void GroupInviteForm::retranslateUi() { headLabel->setText(tr("Groups")); - if (createButton) - { + if (createButton) { createButton->setText(tr("Create new group")); } inviteBox->setTitle(tr("Group invites")); - for (GroupInviteWidget* invite : invites) - { + for (GroupInviteWidget* invite : invites) { invite->retranslateUi(); } } diff --git a/src/widget/form/groupinviteform.h b/src/widget/form/groupinviteform.h index b8ef1de90..0e576b395 100644 --- a/src/widget/form/groupinviteform.h +++ b/src/widget/form/groupinviteform.h @@ -34,9 +34,8 @@ class QPushButton; class QScrollArea; class QSignalMapper; -namespace Ui -{ - class MainWindow; +namespace Ui { +class MainWindow; } class GroupInviteForm : public QWidget diff --git a/src/widget/form/groupinvitewidget.cpp b/src/widget/form/groupinvitewidget.cpp index 16a419d2a..e46048105 100644 --- a/src/widget/form/groupinvitewidget.cpp +++ b/src/widget/form/groupinvitewidget.cpp @@ -43,12 +43,8 @@ GroupInviteWidget::GroupInviteWidget(QWidget* parent, const GroupInvite& invite) , inviteMessageLabel(new CroppingLabel(this)) , inviteInfo(invite) { - connect(acceptButton, &QPushButton::clicked, [=] () { - emit accepted(inviteInfo); - }); - connect(rejectButton, &QPushButton::clicked, [=] () { - emit rejected(inviteInfo); - }); + connect(acceptButton, &QPushButton::clicked, [=]() { emit accepted(inviteInfo); }); + connect(rejectButton, &QPushButton::clicked, [=]() { emit rejected(inviteInfo); }); widgetLayout->addWidget(inviteMessageLabel); widgetLayout->addWidget(acceptButton); widgetLayout->addWidget(rejectButton); @@ -66,9 +62,8 @@ void GroupInviteWidget::retranslateUi() QString date = inviteDate.toString(Settings::getInstance().getDateFormat()); QString time = inviteDate.toString(Settings::getInstance().getTimestampFormat()); - inviteMessageLabel->setText(tr("Invited by %1 on %2 at %3.") - .arg("%1") - .arg(name.toHtmlEscaped(), date, time)); + inviteMessageLabel->setText( + tr("Invited by %1 on %2 at %3.").arg("%1").arg(name.toHtmlEscaped(), date, time)); acceptButton->setText(tr("Join")); rejectButton->setText(tr("Decline")); } diff --git a/src/widget/form/loadhistorydialog.cpp b/src/widget/form/loadhistorydialog.cpp index 075bb3704..3bc9c5861 100644 --- a/src/widget/form/loadhistorydialog.cpp +++ b/src/widget/form/loadhistorydialog.cpp @@ -20,9 +20,9 @@ #include "loadhistorydialog.h" #include "ui_loadhistorydialog.h" -LoadHistoryDialog::LoadHistoryDialog(QWidget* parent) : - QDialog(parent), - ui(new Ui::LoadHistoryDialog) +LoadHistoryDialog::LoadHistoryDialog(QWidget* parent) + : QDialog(parent) + , ui(new Ui::LoadHistoryDialog) { ui->setupUi(this); } @@ -35,8 +35,8 @@ LoadHistoryDialog::~LoadHistoryDialog() QDateTime LoadHistoryDialog::getFromDate() { QDateTime res(ui->fromDate->selectedDate()); - if (res.date().month() != ui->fromDate->monthShown() || res.date().year() != ui->fromDate->yearShown()) - { + if (res.date().month() != ui->fromDate->monthShown() + || res.date().year() != ui->fromDate->yearShown()) { QDate newDate(ui->fromDate->yearShown(), ui->fromDate->monthShown(), 1); res.setDate(newDate); } diff --git a/src/widget/form/loadhistorydialog.h b/src/widget/form/loadhistorydialog.h index 9f50177a1..f80675dda 100644 --- a/src/widget/form/loadhistorydialog.h +++ b/src/widget/form/loadhistorydialog.h @@ -20,8 +20,8 @@ #ifndef LOADHISTORYDIALOG_H #define LOADHISTORYDIALOG_H -#include #include +#include namespace Ui { class LoadHistoryDialog; @@ -38,7 +38,7 @@ public: QDateTime getFromDate(); private: - Ui::LoadHistoryDialog *ui; + Ui::LoadHistoryDialog* ui; }; #endif // LOADHISTORYDIALOG_H diff --git a/src/widget/form/profileform.cpp b/src/widget/form/profileform.cpp index 657a9081c..17e2ec743 100644 --- a/src/widget/form/profileform.cpp +++ b/src/widget/form/profileform.cpp @@ -17,39 +17,40 @@ along with qTox. If not, see . */ -#include "src/core/core.h" -#include "src/nexus.h" -#include "ui_profileform.h" #include "profileform.h" -#include "src/widget/form/settingswidget.h" -#include "src/widget/maskablepixmapwidget.h" -#include "src/widget/form/setpassworddialog.h" -#include "src/widget/contentlayout.h" -#include "src/widget/tool/croppinglabel.h" -#include "src/widget/widget.h" -#include "src/widget/gui.h" -#include "src/widget/style.h" -#include "src/widget/translator.h" -#include "src/persistence/profilelocker.h" -#include "src/persistence/profile.h" -#include "src/persistence/settings.h" +#include "ui_profileform.h" +#include "src/core/core.h" #include "src/net/toxme.h" +#include "src/nexus.h" +#include "src/persistence/profile.h" +#include "src/persistence/profilelocker.h" +#include "src/persistence/settings.h" +#include "src/widget/contentlayout.h" +#include "src/widget/form/setpassworddialog.h" +#include "src/widget/form/settingswidget.h" +#include "src/widget/gui.h" +#include "src/widget/maskablepixmapwidget.h" +#include "src/widget/style.h" +#include "src/widget/tool/croppinglabel.h" +#include "src/widget/translator.h" +#include "src/widget/widget.h" +#include +#include +#include +#include +#include +#include +#include #include #include -#include -#include -#include -#include -#include -#include -#include -#include -#include #include +#include #include +#include -ProfileForm::ProfileForm(QWidget* parent) : - QWidget{parent}, qr{nullptr} +ProfileForm::ProfileForm(QWidget* parent) + : QWidget{parent} + , qr{nullptr} { bodyUI = new Ui::IdentitySettings; bodyUI->setupUi(this); @@ -62,8 +63,8 @@ ProfileForm::ProfileForm(QWidget* parent) : toxId->setFont(Style::getFont(Style::Small)); toxId->setToolTip(bodyUI->toxId->toolTip()); - QVBoxLayout *toxIdGroup = qobject_cast(bodyUI->toxGroup->layout()); - delete toxIdGroup->replaceWidget(bodyUI->toxId, toxId); // Original toxId is in heap, delete it + QVBoxLayout* toxIdGroup = qobject_cast(bodyUI->toxGroup->layout()); + delete toxIdGroup->replaceWidget(bodyUI->toxId, toxId); // Original toxId is in heap, delete it bodyUI->toxId->hide(); /* Toxme section init */ @@ -72,9 +73,7 @@ ProfileForm::ProfileForm(QWidget* parent) : if (toxmeInfo.isEmpty()) // User not registered { showRegisterToxme(); - } - else - { + } else { showExistingToxme(); } @@ -92,14 +91,18 @@ ProfileForm::ProfileForm(QWidget* parent) : profilePicture->setAccessibleName("Profile avatar"); profilePicture->setAccessibleDescription("Set a profile avatar shown to all contacts"); connect(profilePicture, SIGNAL(clicked()), this, SLOT(onAvatarClicked())); - connect(profilePicture, SIGNAL(customContextMenuRequested(const QPoint&)), this, SLOT(showProfilePictureContextMenu(const QPoint&))); - QHBoxLayout *publicGrouplayout = qobject_cast(bodyUI->publicGroup->layout()); + connect(profilePicture, SIGNAL(customContextMenuRequested(const QPoint&)), this, + SLOT(showProfilePictureContextMenu(const QPoint&))); + QHBoxLayout* publicGrouplayout = qobject_cast(bodyUI->publicGroup->layout()); publicGrouplayout->insertWidget(0, profilePicture); publicGrouplayout->insertSpacing(1, 7); timer.setInterval(750); timer.setSingleShot(true); - connect(&timer, &QTimer::timeout, this, [=]() {bodyUI->toxIdLabel->setText(bodyUI->toxIdLabel->text().replace(" ✔", "")); hasCheck = false;}); + connect(&timer, &QTimer::timeout, this, [=]() { + bodyUI->toxIdLabel->setText(bodyUI->toxIdLabel->text().replace(" ✔", "")); + hasCheck = false; + }); connect(bodyUI->toxIdLabel, SIGNAL(clicked()), this, SLOT(copyIdClicked())); connect(toxId, SIGNAL(clicked()), this, SLOT(copyIdClicked())); @@ -112,20 +115,25 @@ ProfileForm::ProfileForm(QWidget* parent) : connect(bodyUI->logoutButton, &QPushButton::clicked, this, &ProfileForm::onLogoutClicked); connect(bodyUI->deletePassButton, &QPushButton::clicked, this, &ProfileForm::onDeletePassClicked); connect(bodyUI->changePassButton, &QPushButton::clicked, this, &ProfileForm::onChangePassClicked); - connect(bodyUI->deletePassButton, &QPushButton::clicked, this, &ProfileForm::setPasswordButtonsText); - connect(bodyUI->changePassButton, &QPushButton::clicked, this, &ProfileForm::setPasswordButtonsText); + connect(bodyUI->deletePassButton, &QPushButton::clicked, this, + &ProfileForm::setPasswordButtonsText); + connect(bodyUI->changePassButton, &QPushButton::clicked, this, + &ProfileForm::setPasswordButtonsText); connect(bodyUI->saveQr, &QPushButton::clicked, this, &ProfileForm::onSaveQrClicked); connect(bodyUI->copyQr, &QPushButton::clicked, this, &ProfileForm::onCopyQrClicked); - connect(bodyUI->toxmeRegisterButton, &QPushButton::clicked, this, &ProfileForm::onRegisterButtonClicked); - connect(bodyUI->toxmeUpdateButton, &QPushButton::clicked, this, &ProfileForm::onRegisterButtonClicked); + connect(bodyUI->toxmeRegisterButton, &QPushButton::clicked, this, + &ProfileForm::onRegisterButtonClicked); + connect(bodyUI->toxmeUpdateButton, &QPushButton::clicked, this, + &ProfileForm::onRegisterButtonClicked); - connect(core, &Core::usernameSet, this, [=](const QString& val) { bodyUI->userName->setText(val); }); - connect(core, &Core::statusMessageSet, this, [=](const QString& val) { bodyUI->statusMessage->setText(val); }); + connect(core, &Core::usernameSet, this, + [=](const QString& val) { bodyUI->userName->setText(val); }); + connect(core, &Core::statusMessageSet, this, + [=](const QString& val) { bodyUI->statusMessage->setText(val); }); - for (QComboBox* cb : findChildren()) - { - cb->installEventFilter(this); - cb->setFocusPolicy(Qt::StrongFocus); + for (QComboBox* cb : findChildren()) { + cb->installEventFilter(this); + cb->setFocusPolicy(Qt::StrongFocus); } retranslateUi(); @@ -147,8 +155,7 @@ ProfileForm::~ProfileForm() bool ProfileForm::isShown() const { - if (profilePicture->isVisible()) - { + if (profilePicture->isVisible()) { window()->windowHandle()->alert(0); return true; } @@ -166,8 +173,8 @@ void ProfileForm::show(ContentLayout* contentLayout) QString appPath = QApplication::applicationDirPath(); QString dirPath = portable ? appPath : defaultPath; - QString dirPrLink = tr("Current profile location: %1") - .arg(QString("%1").arg(dirPath)); + QString dirPrLink = + tr("Current profile location: %1").arg(QString("%1").arg(dirPath)); bodyUI->dirPrLink->setText(dirPrLink); bodyUI->dirPrLink->setOpenExternalLinks(true); @@ -177,24 +184,24 @@ void ProfileForm::show(ContentLayout* contentLayout) bodyUI->userName->selectAll(); } -bool ProfileForm::eventFilter(QObject *object, QEvent *event) +bool ProfileForm::eventFilter(QObject* object, QEvent* event) { - if (object == static_cast(profilePicture) && event->type() == QEvent::MouseButtonPress) - { - QMouseEvent *mouseEvent = static_cast(event); + if (object == static_cast(profilePicture) && event->type() == QEvent::MouseButtonPress) { + QMouseEvent* mouseEvent = static_cast(event); if (mouseEvent->button() == Qt::RightButton) return true; } return false; } -void ProfileForm::showProfilePictureContextMenu(const QPoint &point) +void ProfileForm::showProfilePictureContextMenu(const QPoint& point) { QPoint pos = profilePicture->mapToGlobal(point); QMenu contextMenu; - QAction *removeAction = contextMenu.addAction(style()->standardIcon(QStyle::SP_DialogCancelButton), tr("Remove")); - QAction *selectedItem = contextMenu.exec(pos); + QAction* removeAction = + contextMenu.addAction(style()->standardIcon(QStyle::SP_DialogCancelButton), tr("Remove")); + QAction* selectedItem = contextMenu.exec(pos); if (selectedItem == removeAction) Nexus::getProfile()->removeAvatar(); @@ -204,14 +211,13 @@ void ProfileForm::copyIdClicked() { toxId->selectAll(); QString txt = toxId->text(); - txt.replace('\n',""); + txt.replace('\n', ""); QApplication::clipboard()->setText(txt, QClipboard::Clipboard); if (QApplication::clipboard()->supportsSelection()) - QApplication::clipboard()->setText(txt, QClipboard::Selection); + QApplication::clipboard()->setText(txt, QClipboard::Selection); toxId->setCursorPosition(0); - if (!hasCheck) - { + if (!hasCheck) { bodyUI->toxIdLabel->setText(bodyUI->toxIdLabel->text() + " ✔"); hasCheck = true; } @@ -240,14 +246,13 @@ void ProfileForm::setToxId(const ToxId& id) delete qr; qr = new QRWidget(); - qr->setQRData("tox:"+id.toString()); + qr->setQRData("tox:" + id.toString()); bodyUI->qrCode->setPixmap(QPixmap::fromImage(qr->getImage()->scaledToWidth(150))); } void ProfileForm::onAvatarClicked() { - auto picToPng = [](QPixmap pic) - { + auto picToPng = [](QPixmap pic) { QByteArray bytes; QBuffer buffer(&bytes); buffer.open(QIODevice::WriteOnly); @@ -256,26 +261,21 @@ void ProfileForm::onAvatarClicked() return bytes; }; - QString filename = QFileDialog::getOpenFileName(this, - tr("Choose a profile picture"), - QDir::homePath(), - Nexus::getSupportedImageFilter(), - 0, - QFileDialog::DontUseNativeDialog); + QString filename = QFileDialog::getOpenFileName(this, tr("Choose a profile picture"), + QDir::homePath(), Nexus::getSupportedImageFilter(), + 0, QFileDialog::DontUseNativeDialog); if (filename.isEmpty()) return; QFile file(filename); file.open(QIODevice::ReadOnly); - if (!file.isOpen()) - { + if (!file.isOpen()) { GUI::showError(tr("Error"), tr("Unable to open this file.")); return; } QPixmap pic; - if (!pic.loadFromData(file.readAll())) - { + if (!pic.loadFromData(file.readAll())) { GUI::showError(tr("Error"), tr("Unable to read this image.")); return; } @@ -283,23 +283,20 @@ void ProfileForm::onAvatarClicked() // Limit the avatar size to 64kB // We do a first rescale to 256x256 in case the image was huge, then keep tryng from here QByteArray bytes{picToPng(pic)}; - if (bytes.size() > 65535) - { - pic = pic.scaled(256,256, Qt::KeepAspectRatio, Qt::SmoothTransformation); + if (bytes.size() > 65535) { + pic = pic.scaled(256, 256, Qt::KeepAspectRatio, Qt::SmoothTransformation); bytes = picToPng(pic); } if (bytes.size() > 65535) - bytes = picToPng(pic.scaled(128,128, Qt::KeepAspectRatio, Qt::SmoothTransformation)); + bytes = picToPng(pic.scaled(128, 128, Qt::KeepAspectRatio, Qt::SmoothTransformation)); if (bytes.size() > 65535) - bytes = picToPng(pic.scaled(64,64, Qt::KeepAspectRatio, Qt::SmoothTransformation)); + bytes = picToPng(pic.scaled(64, 64, Qt::KeepAspectRatio, Qt::SmoothTransformation)); if (bytes.size() > 65535) - bytes = picToPng(pic.scaled(32,32, Qt::KeepAspectRatio, Qt::SmoothTransformation)); + bytes = picToPng(pic.scaled(32, 32, Qt::KeepAspectRatio, Qt::SmoothTransformation)); // If this happens, you're really doing it on purpose. - if (bytes.size() > 65535) - { - QMessageBox::critical(this, - tr("Error"), + if (bytes.size() > 65535) { + QMessageBox::critical(this, tr("Error"), tr("The supplied image is too large.\nPlease use another image.")); return; } @@ -312,10 +309,10 @@ void ProfileForm::onRenameClicked() Nexus& nexus = Nexus::getInstance(); QString cur = nexus.getProfile()->getName(); QString title = tr("Rename \"%1\"", "renaming a profile").arg(cur); - do - { - QString name = QInputDialog::getText(this, title, title+":"); - if (name.isEmpty()) break; + do { + QString name = QInputDialog::getText(this, title, title + ":"); + if (name.isEmpty()) + break; name = Core::sanitize(name); if (Profile::exists(name)) @@ -323,9 +320,8 @@ void ProfileForm::onRenameClicked() tr("A profile named \"%1\" already exists.", "rename confirm text").arg(name)); else if (!nexus.getProfile()->rename(name)) GUI::showError(tr("Failed to rename", "rename failed title"), - tr("Couldn't rename the profile to \"%1\"").arg(cur)); - else - { + tr("Couldn't rename the profile to \"%1\"").arg(cur)); + else { prFileLabelUpdate(); break; } @@ -335,44 +331,43 @@ void ProfileForm::onRenameClicked() void ProfileForm::onExportClicked() { QString current = Nexus::getProfile()->getName() + Core::TOX_EXT; - QString path = QFileDialog::getSaveFileName(this, - tr("Export profile", "save dialog title"), + QString path = QFileDialog::getSaveFileName(this, tr("Export profile", "save dialog title"), QDir::home().filePath(current), tr("Tox save file (*.tox)", "save dialog filter"), - 0, - QFileDialog::DontUseNativeDialog); - if (!path.isEmpty()) - { - if (!Nexus::tryRemoveFile(path)) - { - GUI::showWarning(tr("Location not writable","Title of permissions popup"), tr("You do not have permission to write that location. Choose another, or cancel the save dialog.", "text of permissions popup")); + 0, QFileDialog::DontUseNativeDialog); + if (!path.isEmpty()) { + if (!Nexus::tryRemoveFile(path)) { + GUI::showWarning(tr("Location not writable", "Title of permissions popup"), + tr("You do not have permission to write that location. Choose " + "another, or cancel the save dialog.", + "text of permissions popup")); return; } - if (!QFile::copy(Settings::getInstance().getSettingsDirPath()+current, path)) - GUI::showWarning(tr("Failed to copy file"), tr("The file you chose could not be written to.")); + if (!QFile::copy(Settings::getInstance().getSettingsDirPath() + current, path)) + GUI::showWarning(tr("Failed to copy file"), + tr("The file you chose could not be written to.")); } } void ProfileForm::onDeleteClicked() { - if (GUI::askQuestion( - tr("Really delete profile?", "deletion confirmation title"), - tr("Are you sure you want to delete this profile?", "deletion confirmation text"))) - { + if (GUI::askQuestion(tr("Really delete profile?", "deletion confirmation title"), + tr("Are you sure you want to delete this profile?", + "deletion confirmation text"))) { Nexus& nexus = Nexus::getInstance(); QVector manualDeleteFiles = nexus.getProfile()->remove(); - if (!manualDeleteFiles.empty()) - { - QString message = tr("The following files could not be deleted:", "deletion failed text part 1") + "\n\n"; + if (!manualDeleteFiles.empty()) { + QString message = + tr("The following files could not be deleted:", "deletion failed text part 1") + "\n\n"; - for (auto& file : manualDeleteFiles) - { + for (auto& file : manualDeleteFiles) { message = message + file + "\n"; } - message = message + "\n" + tr("Please manually remove them.", "deletion failed text part 2"); + message = + message + "\n" + tr("Please manually remove them.", "deletion failed text part 2"); GUI::showError(tr("Files could not be deleted!", "deletion failed title"), message); } @@ -390,13 +385,10 @@ void ProfileForm::onLogoutClicked() void ProfileForm::setPasswordButtonsText() { - if (Nexus::getProfile()->isEncrypted()) - { + if (Nexus::getProfile()->isEncrypted()) { bodyUI->changePassButton->setText(tr("Change password", "button text")); bodyUI->deletePassButton->setVisible(true); - } - else - { + } else { bodyUI->changePassButton->setText(tr("Set profile password", "button text")); bodyUI->deletePassButton->setVisible(false); } @@ -410,35 +402,35 @@ void ProfileForm::onCopyQrClicked() void ProfileForm::onSaveQrClicked() { QString current = Nexus::getProfile()->getName() + ".png"; - QString path = QFileDialog::getSaveFileName(this, - tr("Save", "save qr image"), + QString path = QFileDialog::getSaveFileName(this, tr("Save", "save qr image"), QDir::home().filePath(current), - tr("Save QrCode (*.png)", "save dialog filter"), - 0, + tr("Save QrCode (*.png)", "save dialog filter"), 0, QFileDialog::DontUseNativeDialog); - if (!path.isEmpty()) - { - if (!Nexus::tryRemoveFile(path)) - { - GUI::showWarning(tr("Location not writable","Title of permissions popup"), tr("You do not have permission to write that location. Choose another, or cancel the save dialog.", "text of permissions popup")); + if (!path.isEmpty()) { + if (!Nexus::tryRemoveFile(path)) { + GUI::showWarning(tr("Location not writable", "Title of permissions popup"), + tr("You do not have permission to write that location. Choose " + "another, or cancel the save dialog.", + "text of permissions popup")); return; } if (!qr->saveImage(path)) - GUI::showWarning(tr("Failed to copy file"), tr("The file you chose could not be written to.")); + GUI::showWarning(tr("Failed to copy file"), + tr("The file you chose could not be written to.")); } } void ProfileForm::onDeletePassClicked() { Profile* pro = Nexus::getProfile(); - if (!pro->isEncrypted()) - { + if (!pro->isEncrypted()) { GUI::showInfo(tr("Nothing to remove"), tr("Your profile does not have a password!")); return; } - if (!GUI::askQuestion(tr("Really delete password?","deletion confirmation title"), - tr("Are you sure you want to delete your password?","deletion confirmation text"))) + if (!GUI::askQuestion(tr("Really delete password?", "deletion confirmation title"), + tr("Are you sure you want to delete your password?", + "deletion confirmation text"))) return; Nexus::getProfile()->setPassword(QString()); @@ -446,7 +438,8 @@ void ProfileForm::onDeletePassClicked() void ProfileForm::onChangePassClicked() { - SetPasswordDialog* dialog = new SetPasswordDialog(tr("Please enter a new password."), QString(), 0); + SetPasswordDialog* dialog = + new SetPasswordDialog(tr("Please enter a new password."), QString(), 0); int r = dialog->exec(); if (r == QDialog::Rejected) return; @@ -459,8 +452,10 @@ void ProfileForm::retranslateUi() { bodyUI->retranslateUi(this); setPasswordButtonsText(); - // We have to add the toxId tooltip here and not in the .ui or Qt won't know how to translate it dynamically - toxId->setToolTip(tr("This bunch of characters tells other Tox clients how to contact you.\nShare it with your friends to communicate.")); + // We have to add the toxId tooltip here and not in the .ui or Qt won't know how to translate it + // dynamically + toxId->setToolTip(tr("This bunch of characters tells other Tox clients how to contact " + "you.\nShare it with your friends to communicate.")); } void ProfileForm::showRegisterToxme() @@ -498,7 +493,7 @@ void ProfileForm::showExistingToxme() void ProfileForm::onRegisterButtonClicked() { - QString name = bodyUI->toxmeUsername->text(); + QString name = bodyUI->toxmeUsername->text(); if (name.isEmpty()) return; @@ -520,8 +515,7 @@ void ProfileForm::onRegisterButtonClicked() Core* newCore = Core::getInstance(); // Make sure the user didn't logout (or logout and login) // before the request is finished, else qTox will crash. - if (oldCore == newCore) - { + if (oldCore == newCore) { switch (code) { case Toxme::Updated: GUI::showInfo(tr("Done!"), tr("Account %1@%2 updated successfully").arg(name, server)); @@ -529,7 +523,9 @@ void ProfileForm::onRegisterButtonClicked() showExistingToxme(); break; case Toxme::Ok: - GUI::showInfo(tr("Done!"), tr("Successfully added %1@%2 to the database. Save your password").arg(name, server)); + GUI::showInfo(tr("Done!"), + tr("Successfully added %1@%2 to the database. Save your password") + .arg(name, server)); Settings::getInstance().setToxme(name, server, bio, privacy, response); showExistingToxme(); break; @@ -537,7 +533,7 @@ void ProfileForm::onRegisterButtonClicked() QString errorMessage = Toxme::getErrorMessage(code); qWarning() << errorMessage; QString translated = Toxme::translateErrorMessage(code); - GUI::showWarning(tr("Toxme error"), translated); + GUI::showWarning(tr("Toxme error"), translated); } bodyUI->toxmeRegisterButton->setEnabled(true); diff --git a/src/widget/form/profileform.h b/src/widget/form/profileform.h index baafe4f57..dd7727a3e 100644 --- a/src/widget/form/profileform.h +++ b/src/widget/form/profileform.h @@ -20,12 +20,12 @@ #ifndef IDENTITYFORM_H #define IDENTITYFORM_H -#include -#include -#include -#include #include "src/core/core.h" #include "src/widget/qrwidget.h" +#include +#include +#include +#include class CroppingLabel; class Core; @@ -40,7 +40,6 @@ class ClickableTE : public QLineEdit { Q_OBJECT public: - signals: void clicked(); @@ -57,7 +56,9 @@ class ProfileForm : public QWidget public: explicit ProfileForm(QWidget* parent = nullptr); ~ProfileForm(); - virtual void show() final{} + virtual void show() final + { + } void show(ContentLayout* contentLayout); bool isShown() const; @@ -66,12 +67,12 @@ signals: void statusMessageChanged(QString); public slots: - void onSelfAvatarLoaded(const QPixmap &pic); + void onSelfAvatarLoaded(const QPixmap& pic); void onLogoutClicked(); private slots: void setPasswordButtonsText(); - void setToxId(const ToxId &id); + void setToxId(const ToxId& id); void copyIdClicked(); void onUserNameEdited(); void onStatusMessageEdited(); @@ -83,7 +84,7 @@ private slots: void onDeletePassClicked(); void onChangePassClicked(); void onAvatarClicked(); - void showProfilePictureContextMenu(const QPoint &point); + void showProfilePictureContextMenu(const QPoint& point); void onRegisterButtonClicked(); private: @@ -92,14 +93,14 @@ private: void prFileLabelUpdate(); private: - bool eventFilter(QObject *object, QEvent *event); + bool eventFilter(QObject* object, QEvent* event); void refreshProfiles(); Ui::IdentitySettings* bodyUI; MaskablePixmapWidget* profilePicture; Core* core; QTimer timer; bool hasCheck = false; - QRWidget *qr; + QRWidget* qr; ClickableTE* toxId; void showRegisterToxme(); }; diff --git a/src/widget/form/setpassworddialog.cpp b/src/widget/form/setpassworddialog.cpp index 1fc974d6b..8a1d9d27f 100644 --- a/src/widget/form/setpassworddialog.cpp +++ b/src/widget/form/setpassworddialog.cpp @@ -32,21 +32,20 @@ SetPasswordDialog::SetPasswordDialog(QString body, QString extraButton, QWidget* { ui->setupUi(this); - connect(ui-> passwordlineEdit, SIGNAL(textChanged(QString)), this, SLOT(onPasswordEdit())); + connect(ui->passwordlineEdit, SIGNAL(textChanged(QString)), this, SLOT(onPasswordEdit())); connect(ui->repasswordlineEdit, SIGNAL(textChanged(QString)), this, SLOT(onPasswordEdit())); ui->body->setText(body + "\n\n"); - QPushButton *ok = ui->buttonBox->button(QDialogButtonBox::Ok); + QPushButton* ok = ui->buttonBox->button(QDialogButtonBox::Ok); ok->setEnabled(false); ok->setText(QApplication::tr("Ok")); - QPushButton *cancel = ui->buttonBox->button(QDialogButtonBox::Cancel); + QPushButton* cancel = ui->buttonBox->button(QDialogButtonBox::Cancel); cancel->setText(QApplication::tr("Cancel")); - if (!extraButton.isEmpty()) - { + if (!extraButton.isEmpty()) { QPushButton* third = new QPushButton(extraButton); ui->buttonBox->addButton(third, QDialogButtonBox::YesRole); - connect(third, &QPushButton::clicked, this, [&](){this->done(Tertiary);}); + connect(third, &QPushButton::clicked, this, [&]() { this->done(Tertiary); }); } } @@ -59,23 +58,16 @@ void SetPasswordDialog::onPasswordEdit() { QString pswd = ui->passwordlineEdit->text(); - if (pswd.isEmpty()) - { + if (pswd.isEmpty()) { ui->buttonBox->button(QDialogButtonBox::Ok)->setEnabled(false); ui->body->setText(body); - } - else if (pswd.length() < 6) - { + } else if (pswd.length() < 6) { ui->buttonBox->button(QDialogButtonBox::Ok)->setEnabled(false); ui->body->setText(body + tr("The password is too short")); - } - else if (pswd != ui->repasswordlineEdit->text()) - { + } else if (pswd != ui->repasswordlineEdit->text()) { ui->buttonBox->button(QDialogButtonBox::Ok)->setEnabled(false); ui->body->setText(body + tr("The password doesn't match.")); - } - else - { + } else { ui->buttonBox->button(QDialogButtonBox::Ok)->setEnabled(true); ui->body->setText(body); } @@ -90,8 +82,7 @@ int SetPasswordDialog::getPasswordStrength(QString pass) double fscore = 0; QHash charCounts; - for (QChar c : pass) - { + for (QChar c : pass) { charCounts[c]++; fscore += 5. / charCounts[c]; } diff --git a/src/widget/form/setpassworddialog.h b/src/widget/form/setpassworddialog.h index ecf416385..fd03fd7e2 100644 --- a/src/widget/form/setpassworddialog.h +++ b/src/widget/form/setpassworddialog.h @@ -31,7 +31,12 @@ class SetPasswordDialog : public QDialog Q_OBJECT public: - enum ReturnCode {Rejected=QDialog::Rejected, Accepted=QDialog::Accepted, Tertiary}; + enum ReturnCode + { + Rejected = QDialog::Rejected, + Accepted = QDialog::Accepted, + Tertiary + }; explicit SetPasswordDialog(QString body, QString extraButton, QWidget* parent = 0); ~SetPasswordDialog(); QString getPassword(); @@ -41,7 +46,7 @@ private slots: void onPasswordEdit(); private: - Ui::SetPasswordDialog *ui; + Ui::SetPasswordDialog* ui; QString body; static const double reasonablePasswordLength; }; diff --git a/src/widget/form/settings/aboutform.cpp b/src/widget/form/settings/aboutform.cpp index db5406ffa..15043b714 100644 --- a/src/widget/form/settings/aboutform.cpp +++ b/src/widget/form/settings/aboutform.cpp @@ -20,8 +20,8 @@ #include "aboutform.h" #include "ui_aboutsettings.h" -#include #include +#include #include #include "src/core/recursivesignalblocker.h" @@ -73,41 +73,39 @@ void AboutForm::replaceVersions() // TODO: When we finally have stable releases: build-in a way to tell // nightly builds from stable releases. - QString TOXCORE_VERSION = QString::number(TOX_VERSION_MAJOR) + "." + - QString::number(TOX_VERSION_MINOR) + "." + - QString::number(TOX_VERSION_PATCH); + QString TOXCORE_VERSION = QString::number(TOX_VERSION_MAJOR) + "." + + QString::number(TOX_VERSION_MINOR) + "." + + QString::number(TOX_VERSION_PATCH); - bodyUI->youAreUsing->setText(tr("You are using qTox version %1.") - .arg(QString(GIT_DESCRIBE))); + bodyUI->youAreUsing->setText(tr("You are using qTox version %1.").arg(QString(GIT_DESCRIBE))); QString commitLink = "https://github.com/qTox/qTox/commit/" + QString(GIT_VERSION); - bodyUI->gitVersion->setText(tr("Commit hash: %1") - .arg(createLink(commitLink, QString(GIT_VERSION)))); + bodyUI->gitVersion->setText( + tr("Commit hash: %1").arg(createLink(commitLink, QString(GIT_VERSION)))); bodyUI->toxCoreVersion->setText(tr("toxcore version: %1").arg(TOXCORE_VERSION)); bodyUI->qtVersion->setText(tr("Qt version: %1").arg(QT_VERSION_STR)); - QString issueBody = QString( - "##### Brief Description\n\n" - "OS: Windows / OS X / Linux (include version and/or distro)\n" - "qTox version: %1\n" - "Commit hash: %2\n" - "toxcore: %3\n" - "Qt: %4\n" - "Hardware: \n…\n\n" - "Reproducible: Always / Almost Always / Sometimes" - " / Rarely / Couldn't Reproduce\n\n" - "##### Steps to reproduce\n\n" - "1. \n2. \n3. …\n\n" - "##### Observed Behavior\n\n\n" - "##### Expected Behavior\n\n\n" - "##### Additional Info\n" - "(links, images, etc go here)\n\n" - "----\n\n" - "More information on how to write good bug reports in the wiki: " - "https://github.com/qTox/qTox/wiki/Writing-Useful-Bug-Reports.\n\n" - "Please remove any unnecessary template section before submitting.") - .arg(GIT_DESCRIBE, GIT_VERSION, TOXCORE_VERSION, QT_VERSION_STR); + QString issueBody = QString("##### Brief Description\n\n" + "OS: Windows / OS X / Linux (include version and/or distro)\n" + "qTox version: %1\n" + "Commit hash: %2\n" + "toxcore: %3\n" + "Qt: %4\n" + "Hardware: \n…\n\n" + "Reproducible: Always / Almost Always / Sometimes" + " / Rarely / Couldn't Reproduce\n\n" + "##### Steps to reproduce\n\n" + "1. \n2. \n3. …\n\n" + "##### Observed Behavior\n\n\n" + "##### Expected Behavior\n\n\n" + "##### Additional Info\n" + "(links, images, etc go here)\n\n" + "----\n\n" + "More information on how to write good bug reports in the wiki: " + "https://github.com/qTox/qTox/wiki/Writing-Useful-Bug-Reports.\n\n" + "Please remove any unnecessary template section before submitting.") + .arg(GIT_DESCRIBE, GIT_VERSION, TOXCORE_VERSION, QT_VERSION_STR); issueBody.replace("#", "%23").replace(":", "%3A"); @@ -119,30 +117,25 @@ void AboutForm::replaceVersions() "`%1` is replaced by translation of `bug tracker`" "\n`%2` is replaced by translation of `Writing Useful Bug Reports`") - .arg(createLink("https://github.com/qTox/qTox/issues", - tr("bug-tracker", - "Replaces `%1` in the `A list of all known…`"))) - .arg(createLink("https://github.com/qTox/qTox/wiki/Writing-Useful-Bug-Reports", - tr("Writing Useful Bug Reports", - "Replaces `%2` in the `A list of all known…`"))) - ); + .arg(createLink("https://github.com/qTox/qTox/issues", + tr("bug-tracker", "Replaces `%1` in the `A list of all known…`"))) + .arg(createLink("https://github.com/qTox/qTox/wiki/Writing-Useful-Bug-Reports", + tr("Writing Useful Bug Reports", + "Replaces `%2` in the `A list of all known…`")))); bodyUI->clickToReport->setText( - createLink("https://github.com/qTox/qTox/issues/new?body=" - + QUrl(issueBody).toEncoded(), - QString("%1") - .arg(tr("Click here to report a bug."))) - ); + createLink("https://github.com/qTox/qTox/issues/new?body=" + QUrl(issueBody).toEncoded(), + QString("%1").arg(tr("Click here to report a bug.")))); - QString authorInfo = QString("

%1

%2

") - .arg(tr("Original author: %1") - .arg(createLink("https://github.com/tux3", "tux3"))) - .arg(tr("See a full list of %1 at Github", - "`%1` is replaced with translation of word `contributors`") - .arg(createLink("https://qtox.github.io/gitstats/authors.html", - tr("contributors", - "Replaces `%1` in `See a full list of…`")))); + QString authorInfo = + QString("

%1

%2

") + .arg(tr("Original author: %1").arg(createLink("https://github.com/tux3", "tux3"))) + .arg( + tr("See a full list of %1 at Github", + "`%1` is replaced with translation of word `contributors`") + .arg(createLink("https://qtox.github.io/gitstats/authors.html", + tr("contributors", "Replaces `%1` in `See a full list of…`")))); bodyUI->authorInfo->setText(authorInfo); } @@ -155,8 +148,9 @@ void AboutForm::replaceVersions() */ QString AboutForm::createLink(QString path, QString text) const { - return QString::fromUtf8("%2") - .arg(path, text); + return QString::fromUtf8( + "%2") + .arg(path, text); } AboutForm::~AboutForm() @@ -173,17 +167,15 @@ void AboutForm::showUpdateProgress() QString version = AutoUpdater::getProgressVersion(); int value = AutoUpdater::getProgressValue(); - if (version.isEmpty()) - { + if (version.isEmpty()) { bodyUI->updateProgress->setVisible(value != 0); bodyUI->updateText->setVisible(value != 0); - } - else - { + } else { if (value == 100) bodyUI->updateText->setText(tr("Restart qTox to install version %1").arg(version)); else - bodyUI->updateText->setText(tr("qTox is downloading update %1", "%1 is the version of the update").arg(version)); + bodyUI->updateText->setText( + tr("qTox is downloading update %1", "%1 is the version of the update").arg(version)); bodyUI->updateProgress->setValue(value); bodyUI->updateProgress->setVisible(value != 0 && value != 100); @@ -191,12 +183,12 @@ void AboutForm::showUpdateProgress() } } -void AboutForm::hideEvent(QHideEvent *) +void AboutForm::hideEvent(QHideEvent*) { progressTimer->stop(); } -void AboutForm::showEvent(QShowEvent *) +void AboutForm::showEvent(QShowEvent*) { progressTimer->start(); } diff --git a/src/widget/form/settings/aboutform.h b/src/widget/form/settings/aboutform.h index dd5c494e8..5722bafe2 100644 --- a/src/widget/form/settings/aboutform.h +++ b/src/widget/form/settings/aboutform.h @@ -30,7 +30,7 @@ namespace Ui { class AboutSettings; } -class AboutForm : public GenericForm +class AboutForm : public GenericForm { Q_OBJECT public: @@ -42,7 +42,6 @@ public: } protected: - private slots: void showUpdateProgress(); virtual void hideEvent(QHideEvent*) final override; diff --git a/src/widget/form/settings/advancedform.cpp b/src/widget/form/settings/advancedform.cpp index cdcb3fb32..752ed4d3c 100644 --- a/src/widget/form/settings/advancedform.cpp +++ b/src/widget/form/settings/advancedform.cpp @@ -21,18 +21,18 @@ #include "ui_advancedsettings.h" #include +#include #include +#include #include #include -#include -#include #include "src/core/core.h" #include "src/core/coreav.h" #include "src/core/recursivesignalblocker.h" #include "src/nexus.h" -#include "src/persistence/settings.h" #include "src/persistence/profile.h" +#include "src/persistence/settings.h" #include "src/widget/gui.h" #include "src/widget/translator.h" @@ -44,15 +44,15 @@ */ AdvancedForm::AdvancedForm() - : GenericForm(QPixmap(":/img/settings/general.png")) - , bodyUI (new Ui::AdvancedSettings) + : GenericForm(QPixmap(":/img/settings/general.png")) + , bodyUI(new Ui::AdvancedSettings) { bodyUI->setupUi(this); // block all child signals during initialization const RecursiveSignalBlocker signalBlocker(this); - Settings &s = Settings::getInstance(); + Settings& s = Settings::getInstance(); bodyUI->cbEnableIPv6->setChecked(s.getEnableIPv6()); bodyUI->cbMakeToxPortable->setChecked(Settings::getInstance().getMakeToxPortable()); bodyUI->cbEnableUDP->setChecked(!s.getForceTCP()); @@ -69,12 +69,13 @@ AdvancedForm::AdvancedForm() "please do %2 change anything here. Changes " "made here may lead to problems with qTox, and even " "to loss of your data, e.g. history.") - .arg(QString("%1").arg(tr("really"))) - .arg(QString("%1").arg(tr("not"))); + .arg(QString("%1").arg(tr("really"))) + .arg(QString("%1").arg(tr("not"))); QString warning = QString("
" "

%1

%2

") - .arg(tr("IMPORTANT NOTE")).arg(warningBody); + .arg(tr("IMPORTANT NOTE")) + .arg(warningBody); bodyUI->warningLabel->setText(warning); @@ -94,10 +95,11 @@ void AdvancedForm::on_cbMakeToxPortable_stateChanged() } void AdvancedForm::on_btnExportLog_clicked() { - QString savefile = QFileDialog::getSaveFileName(this, tr("Save File"), QDir::homePath(), tr("Logs (*.log)"), 0, QFileDialog::DontUseNativeDialog); + QString savefile = + QFileDialog::getSaveFileName(this, tr("Save File"), QDir::homePath(), tr("Logs (*.log)"), 0, + QFileDialog::DontUseNativeDialog); - if (savefile.isNull() || savefile.isEmpty()) - { + if (savefile.isNull() || savefile.isEmpty()) { qDebug() << "Debug log save file was not properly chosen"; return; } @@ -106,12 +108,9 @@ void AdvancedForm::on_btnExportLog_clicked() QString logfile = logFileDir + "qtox.log"; QFile file(logfile); - if (file.exists()) - { + if (file.exists()) { qDebug() << "Found debug log for copying"; - } - else - { + } else { qDebug() << "No debug file found"; return; } @@ -128,44 +127,36 @@ void AdvancedForm::on_btnCopyDebug_clicked() QString logfile = logFileDir + "qtox.log"; QFile file(logfile); - if (!file.exists()) - { + if (!file.exists()) { qDebug() << "No debug file found"; return; } QClipboard* clipboard = QApplication::clipboard(); - if (clipboard) - { + if (clipboard) { QString debugtext; - if (file.open(QIODevice::ReadOnly | QIODevice::Text)) - { + if (file.open(QIODevice::ReadOnly | QIODevice::Text)) { QTextStream in(&file); debugtext = in.readAll(); file.close(); - } - else - { + } else { qDebug() << "Unable to open file for copying to clipboard"; return; } clipboard->setText(debugtext, QClipboard::Clipboard); qDebug() << "Debug log copied to clipboard"; - } - else - { + } else { qDebug() << "Unable to access clipboard"; } - } void AdvancedForm::on_resetButton_clicked() { const QString titile = tr("Reset settings"); - bool result = GUI::askQuestion(titile, - tr("All settings will be reset to default. Are you sure?"), - tr("Yes"), tr("No")); + bool result = + GUI::askQuestion(titile, tr("All settings will be reset to default. Are you sure?"), + tr("Yes"), tr("No")); if (!result) return; @@ -208,10 +199,9 @@ void AdvancedForm::on_proxyType_currentIndexChanged(int index) void AdvancedForm::on_reconnectButton_clicked() { - if (Core::getInstance()->getAv()->anyActiveCalls()) - { + if (Core::getInstance()->getAv()->anyActiveCalls()) { QMessageBox::warning(this, tr("Call active", "popup title"), - tr("You can't disconnect while a call is active!", "popup text")); + tr("You can't disconnect while a call is active!", "popup text")); return; } diff --git a/src/widget/form/settings/avform.cpp b/src/widget/form/settings/avform.cpp index d3c1a1411..98f8dd810 100644 --- a/src/widget/form/settings/avform.cpp +++ b/src/widget/form/settings/avform.cpp @@ -19,8 +19,8 @@ #include "avform.h" -#include #include +#include #include #include @@ -58,8 +58,7 @@ AVForm::AVForm() cbEnableTestSound->setChecked(s.getEnableTestSound()); - cbEnableTestSound->setToolTip( - tr("Play a test sound while changing the output volume.")); + cbEnableTestSound->setToolTip(tr("Play a test sound while changing the output volume.")); connect(rescanButton, &QPushButton::clicked, this, &AVForm::rescanDevices); @@ -67,22 +66,21 @@ AVForm::AVForm() playbackSlider->setValue(s.getOutVolume()); playbackSlider->installEventFilter(this); - microphoneSlider->setToolTip( - tr("Use slider to set the gain of your input device ranging" - " from %1dB to %2dB.").arg(audio.minInputGain()) - .arg(audio.maxInputGain())); + microphoneSlider->setToolTip(tr("Use slider to set the gain of your input device ranging" + " from %1dB to %2dB.") + .arg(audio.minInputGain()) + .arg(audio.maxInputGain())); microphoneSlider->setMinimum(qRound(audio.minInputGain()) * 10); microphoneSlider->setMaximum(qRound(audio.maxInputGain()) * 10); microphoneSlider->setTickPosition(QSlider::TicksBothSides); microphoneSlider->setTickInterval( - (qAbs(microphoneSlider->minimum()) + - microphoneSlider->maximum()) / 4); + (qAbs(microphoneSlider->minimum()) + microphoneSlider->maximum()) / 4); microphoneSlider->setTracking(false); microphoneSlider->installEventFilter(this); eventsInit(); - QDesktopWidget *desktop = QApplication::desktop(); + QDesktopWidget* desktop = QApplication::desktop(); connect(desktop, &QDesktopWidget::resized, this, &AVForm::rescanDevices); connect(desktop, &QDesktopWidget::screenCountChanged, this, &AVForm::rescanDevices); @@ -103,8 +101,7 @@ void AVForm::hideEvent(QHideEvent* event) subscribedToAudioIn = false; } - if (camVideoSurface) - { + if (camVideoSurface) { camVideoSurface->setSource(nullptr); killVideoSurface(); } @@ -129,7 +126,7 @@ void AVForm::showEvent(QShowEvent* event) GenericForm::showEvent(event); } -void AVForm::open(const QString &devName, const VideoMode &mode) +void AVForm::open(const QString& devName, const VideoMode& mode) { QRect rect = mode.toRect(); Settings::getInstance().setCamVideoRes(rect); @@ -153,10 +150,8 @@ void AVForm::on_videoModescomboBox_currentIndexChanged(int index) QString devName = videoDeviceList[devIndex].first; VideoMode mode = videoModes[index]; - if (CameraDevice::isScreen(devName) && mode == VideoMode()) - { - if (Settings::getInstance().getScreenGrabbed()) - { + if (CameraDevice::isScreen(devName) && mode == VideoMode()) { + if (Settings::getInstance().getScreenGrabbed()) { VideoMode mode(Settings::getInstance().getScreenRegion()); open(devName, mode); return; @@ -165,8 +160,7 @@ void AVForm::on_videoModescomboBox_currentIndexChanged(int index) // note: grabber is self-managed and will destroy itself when done ScreenshotGrabber* screenshotGrabber = new ScreenshotGrabber; - auto onGrabbed = [screenshotGrabber, devName, this] (QRect region) - { + auto onGrabbed = [screenshotGrabber, devName, this](QRect region) { VideoMode mode(region); mode.width = mode.width / 2 * 2; mode.height = mode.height / 2 * 2; @@ -182,7 +176,8 @@ void AVForm::on_videoModescomboBox_currentIndexChanged(int index) open(devName, mode); }; - connect(screenshotGrabber, &ScreenshotGrabber::regionChosen, this, onGrabbed, Qt::QueuedConnection); + connect(screenshotGrabber, &ScreenshotGrabber::regionChosen, this, onGrabbed, + Qt::QueuedConnection); screenshotGrabber->showGrabber(); return; } @@ -191,7 +186,7 @@ void AVForm::on_videoModescomboBox_currentIndexChanged(int index) open(devName, mode); } -void AVForm::selectBestModes(QVector &allVideoModes) +void AVForm::selectBestModes(QVector& allVideoModes) { // Identify the best resolutions available for the supposed XXXXp resolutions. std::map idealModes; @@ -203,16 +198,14 @@ void AVForm::selectBestModes(QVector &allVideoModes) idealModes[1080] = VideoMode(1920, 1080); std::map bestModeInds; - for (int i = 0; i < allVideoModes.size(); ++i) - { + for (int i = 0; i < allVideoModes.size(); ++i) { VideoMode mode = allVideoModes[i]; // PS3-Cam protection, everything above 60fps makes no sense if (mode.FPS > 60) continue; - for (auto iter = idealModes.begin(); iter != idealModes.end(); ++iter) - { + for (auto iter = idealModes.begin(); iter != idealModes.end(); ++iter) { int res = iter->first; VideoMode idealMode = iter->second; // don't take approximately correct resolutions unless they really @@ -220,25 +213,21 @@ void AVForm::selectBestModes(QVector &allVideoModes) if (mode.norm(idealMode) > 300) continue; - if (bestModeInds.find(res) == bestModeInds.end()) - { + if (bestModeInds.find(res) == bestModeInds.end()) { bestModeInds[res] = i; continue; } int index = bestModeInds[res]; VideoMode best = allVideoModes[index]; - if (mode.norm(idealMode) < best.norm(idealMode)) - { + if (mode.norm(idealMode) < best.norm(idealMode)) { bestModeInds[res] = i; continue; } - if (mode.norm(idealMode) == best.norm(idealMode)) - { + if (mode.norm(idealMode) == best.norm(idealMode)) { // prefer higher FPS and "better" pixel formats - if (mode.FPS > best.FPS) - { + if (mode.FPS > best.FPS) { bestModeInds[res] = i; continue; } @@ -251,16 +240,12 @@ void AVForm::selectBestModes(QVector &allVideoModes) } QVector newVideoModes; - for (auto it = bestModeInds.rbegin(); it != bestModeInds.rend(); ++it) - { + for (auto it = bestModeInds.rbegin(); it != bestModeInds.rend(); ++it) { VideoMode mode = allVideoModes[it->second]; - if (newVideoModes.empty()) - { + if (newVideoModes.empty()) { newVideoModes.push_back(mode); - } - else - { + } else { int size = getModeSize(mode); auto result = std::find_if(newVideoModes.cbegin(), newVideoModes.cend(), [size](VideoMode mode) { return getModeSize(mode) == size; }); @@ -278,13 +263,13 @@ void AVForm::fillCameraModesComboBox() bool previouslyBlocked = videoModescomboBox->blockSignals(true); videoModescomboBox->clear(); - for(int i = 0; i < videoModes.size(); ++i) - { + for (int i = 0; i < videoModes.size(); ++i) { VideoMode mode = videoModes[i]; QString str; QString pixelFormat = CameraDevice::getPixelFormatString(mode.pixel_format); - qDebug("width: %d, height: %d, FPS: %f, pixel format: %s\n", mode.width, mode.height, mode.FPS, pixelFormat.toStdString().c_str()); + qDebug("width: %d, height: %d, FPS: %f, pixel format: %s\n", mode.width, mode.height, + mode.FPS, pixelFormat.toStdString().c_str()); if (mode.height && mode.width) str += QString("%1p").arg(mode.height); @@ -305,12 +290,10 @@ int AVForm::searchPreferredIndex() QRect prefRes = Settings::getInstance().getCamVideoRes(); quint16 prefFPS = Settings::getInstance().getCamVideoFPS(); - for (int i = 0; i < videoModes.size(); ++i) - { + for (int i = 0; i < videoModes.size(); ++i) { VideoMode mode = videoModes[i]; - if (mode.width == prefRes.width() - && mode.height == prefRes.height() - && static_cast(mode.FPS) == prefFPS) + if (mode.width == prefRes.width() && mode.height == prefRes.height() + && static_cast(mode.FPS) == prefFPS) return i; } @@ -322,13 +305,11 @@ void AVForm::fillScreenModesComboBox() bool previouslyBlocked = videoModescomboBox->blockSignals(true); videoModescomboBox->clear(); - for(int i = 0; i < videoModes.size(); ++i) - { + for (int i = 0; i < videoModes.size(); ++i) { VideoMode mode = videoModes[i]; QString pixelFormat = CameraDevice::getPixelFormatString(mode.pixel_format); - qDebug("%dx%d+%d,%d FPS: %f, pixel format: %s\n", mode.width, - mode.height, mode.x, mode.y, mode.FPS, - pixelFormat.toStdString().c_str()); + qDebug("%dx%d+%d,%d FPS: %f, pixel format: %s\n", mode.width, mode.height, mode.x, mode.y, + mode.FPS, pixelFormat.toStdString().c_str()); QString name; if (mode.width && mode.height) @@ -344,8 +325,7 @@ void AVForm::fillScreenModesComboBox() void AVForm::updateVideoModes(int curIndex) { - if (curIndex < 0 || curIndex >= videoDeviceList.size()) - { + if (curIndex < 0 || curIndex >= videoDeviceList.size()) { qWarning() << "Invalid index:" << curIndex; return; } @@ -354,23 +334,19 @@ void AVForm::updateVideoModes(int curIndex) qDebug("available Modes:"); bool isScreen = CameraDevice::isScreen(devName); - if (isScreen) - { + if (isScreen) { // Add extra video mode to region selection allVideoModes.push_back(VideoMode()); videoModes = allVideoModes; fillScreenModesComboBox(); - } - else - { + } else { selectBestModes(allVideoModes); videoModes = allVideoModes; fillCameraModesComboBox(); } int preferedIndex = searchPreferredIndex(); - if (preferedIndex != -1) - { + if (preferedIndex != -1) { Settings::getInstance().setScreenGrabbed(false); videoModescomboBox->blockSignals(true); videoModescomboBox->setCurrentIndex(preferedIndex); @@ -379,8 +355,7 @@ void AVForm::updateVideoModes(int curIndex) return; } - if (isScreen) - { + if (isScreen) { QRect rect = Settings::getInstance().getScreenRegion(); VideoMode mode(rect); @@ -428,14 +403,13 @@ void AVForm::getVideoDevices() QString settingsInDev = Settings::getInstance().getVideoDev(); int videoDevIndex = 0; videoDeviceList = CameraDevice::getDeviceList(); - //prevent currentIndexChanged to be fired while adding items + // prevent currentIndexChanged to be fired while adding items videoDevCombobox->blockSignals(true); videoDevCombobox->clear(); - for (QPair device : videoDeviceList) - { + for (QPair device : videoDeviceList) { videoDevCombobox->addItem(device.second); if (device.first == settingsInDev) - videoDevIndex = videoDevCombobox->count()-1; + videoDevIndex = videoDevCombobox->count() - 1; } videoDevCombobox->setCurrentIndex(videoDevIndex); videoDevCombobox->blockSignals(false); @@ -459,8 +433,7 @@ void AVForm::getAudioInDevices() int idx = 0; bool enabled = Settings::getInstance().getAudioInDevEnabled(); - if (enabled && deviceNames.size() > 1) - { + if (enabled && deviceNames.size() > 1) { QString dev = Settings::getInstance().getInDev(); idx = qMax(deviceNames.indexOf(dev), 1); } @@ -479,8 +452,7 @@ void AVForm::getAudioOutDevices() int idx = 0; bool enabled = Settings::getInstance().getAudioOutDevEnabled(); - if (enabled && deviceNames.size() > 1) - { + if (enabled && deviceNames.size() > 1) { QString dev = Settings::getInstance().getOutDev(); idx = qMax(deviceNames.indexOf(dev), 1); } @@ -524,8 +496,7 @@ void AVForm::on_playbackSlider_valueChanged(int value) Settings::getInstance().setOutVolume(value); Audio& audio = Audio::getInstance(); - if (audio.isOutputReady()) - { + if (audio.isOutputReady()) { const qreal percentage = value / 100.0; audio.setOutputVolume(percentage); @@ -568,7 +539,7 @@ void AVForm::killVideoSurface() if (!camVideoSurface) return; - QLayoutItem *child; + QLayoutItem* child; while ((child = gridLayout->takeAt(0)) != 0) delete child; diff --git a/src/widget/form/settings/avform.h b/src/widget/form/settings/avform.h index ac11eefb4..2bdaf125f 100644 --- a/src/widget/form/settings/avform.h +++ b/src/widget/form/settings/avform.h @@ -20,9 +20,9 @@ #ifndef AVFORM_H #define AVFORM_H +#include #include #include -#include #include "genericsettings.h" #include "ui_avform.h" @@ -38,7 +38,10 @@ class AVForm : public GenericForm, private Ui::AVForm public: AVForm(); ~AVForm(); - QString getFormName() final override {return tr("Audio/Video");} + QString getFormName() final override + { + return tr("Audio/Video"); + } private: void getAudioInDevices(); @@ -46,7 +49,7 @@ private: void getVideoDevices(); static int getModeSize(VideoMode mode); - void selectBestModes(QVector &allVideoModes); + void selectBestModes(QVector& allVideoModes); void fillCameraModesComboBox(); void fillScreenModesComboBox(); int searchPreferredIndex(); @@ -75,13 +78,13 @@ protected: private: void hideEvent(QHideEvent* event) final override; - void showEvent(QShowEvent*event) final override; - void open(const QString &devName, const VideoMode &mode); + void showEvent(QShowEvent* event) final override; + void open(const QString& devName, const VideoMode& mode); private: bool subscribedToAudioIn; - VideoSurface *camVideoSurface; - CameraSource &camera; + VideoSurface* camVideoSurface; + CameraSource& camera; QVector> videoDeviceList; QVector videoModes; }; diff --git a/src/widget/form/settings/generalform.cpp b/src/widget/form/settings/generalform.cpp index a9dc7e69a..1b15ff771 100644 --- a/src/widget/form/settings/generalform.cpp +++ b/src/widget/form/settings/generalform.cpp @@ -35,87 +35,26 @@ #include "src/widget/translator.h" #include "src/widget/widget.h" -static QStringList locales = {"ar", - "be", - "bg", - "cs", - "da", - "de", - "et", - "el", - "en", - "es", - "eo", - "fr", - "ko", - "he", - "hr", - "it", - "sw", - "lt", - "jbo", - "hu", - "nl", - "ja", - "no_nb", - "pr", - "pl", - "pt", - "ru", - "sk", - "sl", - "fi", - "sv", - "tr", - "ug", - "uk", - "zh_CN", - "zh_TW" -}; -static QStringList langs = {"Arabic", - "Беларуская", - "Български", - "Čeština", - "Dansk", - "Deutsch", - "Eesti", - "Ελληνικά", - "English", - "Español", - "Esperanto", - "Français", - "한국어", - "עברית", - "Hrvatski", - "Italiano", - "Kiswahili", - "Lietuvių", - "Lojban", - "Magyar", - "Nederlands", - "日本語", - "Norsk Bokmål", - "Pirate", - "Polski", - "Português", - "Русский", - "Slovenčina", - "Slovenščina", - "Suomi", - "Svenska", - "Türkçe", - "ئۇيغۇرچە", - "Українська", - "中文(中国)", - "繁體中文(台灣)" -}; +static QStringList locales = {"ar", "be", "bg", "cs", "da", "de", "et", "el", "en", + "es", "eo", "fr", "ko", "he", "hr", "it", "sw", "lt", + "jbo", "hu", "nl", "ja", "no_nb", "pr", "pl", "pt", "ru", + "sk", "sl", "fi", "sv", "tr", "ug", "uk", "zh_CN", "zh_TW"}; +static QStringList langs = {"Arabic", "Беларуская", "Български", "Čeština", + "Dansk", "Deutsch", "Eesti", "Ελληνικά", + "English", "Español", "Esperanto", "Français", + "한국어", "עברית", "Hrvatski", "Italiano", + "Kiswahili", "Lietuvių", "Lojban", "Magyar", + "Nederlands", "日本語", "Norsk Bokmål", "Pirate", + "Polski", "Português", "Русский", "Slovenčina", + "Slovenščina", "Suomi", "Svenska", "Türkçe", + "ئۇيغۇرچە", "Українська", "中文(中国)", "繁體中文(台灣)"}; /** * @class GeneralForm * * This form contains all settings that are not suited to other forms */ -GeneralForm::GeneralForm(SettingsWidget *myParent) +GeneralForm::GeneralForm(SettingsWidget* myParent) : GenericForm(QPixmap(":/img/settings/general.png")) , bodyUI(new Ui::GeneralSettings) { @@ -161,7 +100,8 @@ GeneralForm::GeneralForm(SettingsWidget *myParent) bodyUI->autoacceptFiles->setChecked(s.getAutoSaveEnabled()); #ifndef QTOX_PLATFORM_EXT - bodyUI->autoAwayLabel->setEnabled(false); // these don't seem to change the appearance of the widgets, + bodyUI->autoAwayLabel->setEnabled( + false); // these don't seem to change the appearance of the widgets, bodyUI->autoAwaySpinBox->setEnabled(false); // though they are unusable #endif @@ -249,11 +189,12 @@ void GeneralForm::on_autoacceptFiles_stateChanged() void GeneralForm::on_autoSaveFilesDir_clicked() { QString previousDir = Settings::getInstance().getGlobalAutoAcceptDir(); - QString directory = QFileDialog::getExistingDirectory(0, - tr("Choose an auto accept directory", "popup title"), //opens in home directory - QDir::homePath(), - QFileDialog::DontUseNativeDialog); - if (directory.isEmpty()) // cancel was pressed + QString directory = + QFileDialog::getExistingDirectory(0, tr("Choose an auto accept directory", + "popup title"), // opens in home directory + QDir::homePath(), + QFileDialog::DontUseNativeDialog); + if (directory.isEmpty()) // cancel was pressed directory = previousDir; Settings::getInstance().setGlobalAutoAcceptDir(directory); diff --git a/src/widget/form/settings/generalform.h b/src/widget/form/settings/generalform.h index f188c76e5..47e03a92e 100644 --- a/src/widget/form/settings/generalform.h +++ b/src/widget/form/settings/generalform.h @@ -32,7 +32,7 @@ class GeneralForm : public GenericForm { Q_OBJECT public: - explicit GeneralForm(SettingsWidget *parent); + explicit GeneralForm(SettingsWidget* parent); ~GeneralForm(); virtual QString getFormName() final override { @@ -61,8 +61,8 @@ private: void retranslateUi(); private: - Ui::GeneralSettings *bodyUI; - SettingsWidget *parent; + Ui::GeneralSettings* bodyUI; + SettingsWidget* parent; }; #endif diff --git a/src/widget/form/settings/genericsettings.cpp b/src/widget/form/settings/genericsettings.cpp index d966c948f..6551d48a6 100644 --- a/src/widget/form/settings/genericsettings.cpp +++ b/src/widget/form/settings/genericsettings.cpp @@ -12,7 +12,7 @@ * It provides correct behaviour of controls for settings forms. */ -GenericForm::GenericForm(const QPixmap &icon) +GenericForm::GenericForm(const QPixmap& icon) : formIcon(icon) { } @@ -32,19 +32,17 @@ QPixmap GenericForm::getFormIcon() */ void GenericForm::eventsInit() { - for (QComboBox *cb : findChildren()) - { + for (QComboBox* cb : findChildren()) { cb->installEventFilter(this); cb->setFocusPolicy(Qt::StrongFocus); } - for (QSpinBox *sp : findChildren()) - { + for (QSpinBox* sp : findChildren()) { sp->installEventFilter(this); sp->setFocusPolicy(Qt::WheelFocus); } - for (QCheckBox *cb : findChildren()) // this one is to allow scrolling on checkboxes + for (QCheckBox* cb : findChildren()) // this one is to allow scrolling on checkboxes cb->installEventFilter(this); } @@ -54,13 +52,11 @@ void GenericForm::eventsInit() * @param e Event object. * @return True to stop it being handled further, false otherwise. */ -bool GenericForm::eventFilter(QObject *o, QEvent *e) +bool GenericForm::eventFilter(QObject* o, QEvent* e) { - if ((e->type() == QEvent::Wheel) && - (qobject_cast(o) || - qobject_cast(o) || - qobject_cast(o))) - { + if ((e->type() == QEvent::Wheel) + && (qobject_cast(o) || qobject_cast(o) + || qobject_cast(o))) { e->ignore(); return true; } diff --git a/src/widget/form/settings/genericsettings.h b/src/widget/form/settings/genericsettings.h index 08363d45a..363d3b80d 100644 --- a/src/widget/form/settings/genericsettings.h +++ b/src/widget/form/settings/genericsettings.h @@ -24,14 +24,16 @@ class GenericForm : public QWidget { Q_OBJECT public: - explicit GenericForm(const QPixmap &icon); - virtual ~GenericForm() {} + explicit GenericForm(const QPixmap& icon); + virtual ~GenericForm() + { + } virtual QString getFormName() = 0; QPixmap getFormIcon(); protected: - bool eventFilter(QObject *o, QEvent *e) final override; + bool eventFilter(QObject* o, QEvent* e) final override; void eventsInit(); protected: diff --git a/src/widget/form/settings/privacyform.cpp b/src/widget/form/settings/privacyform.cpp index cf58d713e..aa652a2a4 100644 --- a/src/widget/form/settings/privacyform.cpp +++ b/src/widget/form/settings/privacyform.cpp @@ -59,13 +59,13 @@ void PrivacyForm::on_cbKeepHistory_stateChanged() { Settings::getInstance().setEnableLogging(bodyUI->cbKeepHistory->isChecked()); Widget::getInstance()->clearAllReceipts(); - if (!bodyUI->cbKeepHistory->isChecked()) - { + if (!bodyUI->cbKeepHistory->isChecked()) { QMessageBox::StandardButton dialogDelHistory; - dialogDelHistory = QMessageBox::question(0, tr("Confirmation"), tr("Do you want to permanently delete all chat history?"), - QMessageBox::Yes|QMessageBox::No); - if (dialogDelHistory == QMessageBox::Yes) - { + dialogDelHistory = + QMessageBox::question(0, tr("Confirmation"), + tr("Do you want to permanently delete all chat history?"), + QMessageBox::Yes | QMessageBox::No); + if (dialogDelHistory == QMessageBox::Yes) { Nexus::getProfile()->getHistory()->eraseHistory(); } } @@ -101,7 +101,7 @@ void PrivacyForm::on_randomNosapamButton_clicked() uint32_t newNospam{0}; for (int i = 0; i < 4; ++i) - newNospam = (newNospam<<8) + (qrand() % 256); // Generate byte by byte. For some reason. + newNospam = (newNospam << 8) + (qrand() % 256); // Generate byte by byte. For some reason. Core::getInstance()->setNospam(newNospam); bodyUI->nospamLineEdit->setText(Core::getInstance()->getSelfId().getNoSpamString()); @@ -111,8 +111,7 @@ void PrivacyForm::on_nospamLineEdit_textChanged() { QString str = bodyUI->nospamLineEdit->text(); int curs = bodyUI->nospamLineEdit->cursorPosition(); - if (str.length() != 8) - { + if (str.length() != 8) { str = QString("00000000").replace(0, str.length(), str); bodyUI->nospamLineEdit->setText(str); bodyUI->nospamLineEdit->setCursorPosition(curs); diff --git a/src/widget/form/settings/userinterfaceform.cpp b/src/widget/form/settings/userinterfaceform.cpp index cca572db7..20c0b6fea 100644 --- a/src/widget/form/settings/userinterfaceform.cpp +++ b/src/widget/form/settings/userinterfaceform.cpp @@ -57,8 +57,8 @@ * * Restores all controls from the settings. */ -UserInterfaceForm::UserInterfaceForm(SettingsWidget* myParent) : - GenericForm(QPixmap(":/img/settings/general.png")) +UserInterfaceForm::UserInterfaceForm(SettingsWidget* myParent) + : GenericForm(QPixmap(":/img/settings/general.png")) { parent = myParent; @@ -68,7 +68,7 @@ UserInterfaceForm::UserInterfaceForm(SettingsWidget* myParent) : // block all child signals during initialization const RecursiveSignalBlocker signalBlocker(this); - Settings &s = Settings::getInstance(); + Settings& s = Settings::getInstance(); const QFont chatBaseFont = s.getChatMessageFont(); bodyUI->txtChatFontSize->setValue(QFontInfo(chatBaseFont).pixelSize()); bodyUI->txtChatFont->setCurrentFont(chatBaseFont); @@ -92,8 +92,7 @@ UserInterfaceForm::UserInterfaceForm(SettingsWidget* myParent) : for (auto entry : SmileyPack::listSmileyPacks()) bodyUI->smileyPackBrowser->addItem(entry.first, entry.second); - smileLabels = {bodyUI->smile1, bodyUI->smile2, bodyUI->smile3, - bodyUI->smile4, bodyUI->smile5}; + smileLabels = {bodyUI->smile1, bodyUI->smile2, bodyUI->smile3, bodyUI->smile4, bodyUI->smile5}; int currentPack = bodyUI->smileyPackBrowser->findData(s.getSmileyPack()); bodyUI->smileyPackBrowser->setCurrentIndex(currentPack); @@ -119,9 +118,10 @@ UserInterfaceForm::UserInterfaceForm(SettingsWidget* myParent) : QLocale ql; QStringList timeFormats; - timeFormats << ql.timeFormat(QLocale::ShortFormat) - << ql.timeFormat(QLocale::LongFormat) - << "hh:mm AP" << "hh:mm:ss AP" << "hh:mm:ss"; + timeFormats << ql.timeFormat(QLocale::ShortFormat) << ql.timeFormat(QLocale::LongFormat) + << "hh:mm AP" + << "hh:mm:ss AP" + << "hh:mm:ss"; timeFormats.removeDuplicates(); bodyUI->timestamp->addItems(timeFormats); @@ -137,12 +137,13 @@ UserInterfaceForm::UserInterfaceForm(SettingsWidget* myParent) : on_timestamp_editTextChanged(timeFormat); QStringList dateFormats; - dateFormats << QStringLiteral("yyyy-MM-dd") // ISO 8601 + dateFormats << QStringLiteral("yyyy-MM-dd") // ISO 8601 // format strings from system locale - << ql.dateFormat(QLocale::LongFormat) - << ql.dateFormat(QLocale::ShortFormat) - << ql.dateFormat(QLocale::NarrowFormat) - << "dd-MM-yyyy" << "d-MM-yyyy" << "dddd dd-MM-yyyy" << "dddd d-MM"; + << ql.dateFormat(QLocale::LongFormat) << ql.dateFormat(QLocale::ShortFormat) + << ql.dateFormat(QLocale::NarrowFormat) << "dd-MM-yyyy" + << "d-MM-yyyy" + << "dddd dd-MM-yyyy" + << "dddd d-MM"; dateFormats.removeDuplicates(); bodyUI->dateFormats->addItems(dateFormats); @@ -208,7 +209,7 @@ void UserInterfaceForm::on_useEmoticons_stateChanged() void UserInterfaceForm::on_textStyleComboBox_currentTextChanged() { Settings::StyleType styleType = - static_cast(bodyUI->textStyleComboBox->currentIndex()); + static_cast(bodyUI->textStyleComboBox->currentIndex()); Settings::getInstance().setStylePreference(styleType); } @@ -227,8 +228,7 @@ void UserInterfaceForm::reloadSmileys() QList emoticons = SmileyPack::getInstance().getEmoticons(); // sometimes there are no emoticons available, don't crash in this case - if (emoticons.isEmpty()) - { + if (emoticons.isEmpty()) { qDebug() << "reloadSmilies: No emoticons found"; return; } @@ -237,20 +237,18 @@ void UserInterfaceForm::reloadSmileys() for (int i = 0; i < emoticons.size(); ++i) smileys.push_front(emoticons.at(i).first()); - const QSize size(18,18); - for (int i = 0; i < smileLabels.size(); ++i) - { + const QSize size(18, 18); + for (int i = 0; i < smileLabels.size(); ++i) { QIcon icon = SmileyPack::getInstance().getAsIcon(smileys[i]); smileLabels[i]->setPixmap(icon.pixmap(size)); smileLabels[i]->setToolTip(smileys[i]); } - //set maximum size of emoji + // set maximum size of emoji QDesktopWidget desktop; // 8 is the count of row and column in emoji's in widget const int sideSize = 8; - int maxSide = qMin(desktop.geometry().height() / sideSize, - desktop.geometry().width() / sideSize); + int maxSide = qMin(desktop.geometry().height() / sideSize, desktop.geometry().width() / sideSize); QSize maxSize(maxSide, maxSide); QIcon icon = SmileyPack::getInstance().getAsIcon(smileys[0]); @@ -320,8 +318,7 @@ void UserInterfaceForm::retranslateUi() static_cast(Settings::getInstance().getStylePreference())); QStringList colorThemes(Style::getThemeColorNames()); - for (int i = 0; i < colorThemes.size(); ++i) - { + for (int i = 0; i < colorThemes.size(); ++i) { bodyUI->themeColorCBox->setItemText(i, colorThemes[i]); } @@ -345,8 +342,7 @@ void UserInterfaceForm::on_txtChatFontSize_valueChanged(int px) QFont tmpFont = s.getChatMessageFont(); const int fontSize = QFontInfo(tmpFont).pixelSize(); - if (px != fontSize) - { + if (px != fontSize) { tmpFont.setPixelSize(px); s.setChatMessageFont(tmpFont); } diff --git a/src/widget/form/settings/userinterfaceform.h b/src/widget/form/settings/userinterfaceform.h index f6ca9a821..185c553a4 100644 --- a/src/widget/form/settings/userinterfaceform.h +++ b/src/widget/form/settings/userinterfaceform.h @@ -33,7 +33,10 @@ class UserInterfaceForm : public GenericForm public: explicit UserInterfaceForm(SettingsWidget* myParent); ~UserInterfaceForm(); - virtual QString getFormName() final override {return tr("User Interface");} + virtual QString getFormName() final override + { + return tr("User Interface"); + } private slots: void on_smileyPackBrowser_currentIndexChanged(int index); diff --git a/src/widget/form/settings/verticalonlyscroller.cpp b/src/widget/form/settings/verticalonlyscroller.cpp index 612836534..0269e8d0d 100644 --- a/src/widget/form/settings/verticalonlyscroller.cpp +++ b/src/widget/form/settings/verticalonlyscroller.cpp @@ -22,19 +22,19 @@ #include "verticalonlyscroller.h" -VerticalOnlyScroller::VerticalOnlyScroller(QWidget* parent) : - QScrollArea(parent) +VerticalOnlyScroller::VerticalOnlyScroller(QWidget* parent) + : QScrollArea(parent) { } -void VerticalOnlyScroller::resizeEvent(QResizeEvent *event) +void VerticalOnlyScroller::resizeEvent(QResizeEvent* event) { QScrollArea::resizeEvent(event); if (widget()) widget()->setMaximumWidth(event->size().width()); } -void VerticalOnlyScroller::showEvent(QShowEvent *event) +void VerticalOnlyScroller::showEvent(QShowEvent* event) { QScrollArea::showEvent(event); if (widget()) diff --git a/src/widget/form/settings/verticalonlyscroller.h b/src/widget/form/settings/verticalonlyscroller.h index 22fff89c9..713df4287 100644 --- a/src/widget/form/settings/verticalonlyscroller.h +++ b/src/widget/form/settings/verticalonlyscroller.h @@ -32,8 +32,8 @@ public: explicit VerticalOnlyScroller(QWidget* parent = 0); protected: - virtual void resizeEvent(QResizeEvent *event) final override; - virtual void showEvent(QShowEvent *event) final override; + virtual void resizeEvent(QResizeEvent* event) final override; + virtual void showEvent(QShowEvent* event) final override; }; #endif // VERTICALONLYSCROLLER_H diff --git a/src/widget/form/settingswidget.cpp b/src/widget/form/settingswidget.cpp index ab122f9b6..c55a56544 100644 --- a/src/widget/form/settingswidget.cpp +++ b/src/widget/form/settingswidget.cpp @@ -19,20 +19,20 @@ #include "settingswidget.h" -#include #include +#include #include #include "src/video/camerasource.h" -#include "src/widget/widget.h" -#include "src/widget/form/settings/generalform.h" -#include "src/widget/form/settings/userinterfaceform.h" -#include "src/widget/form/settings/privacyform.h" -#include "src/widget/form/settings/avform.h" -#include "src/widget/form/settings/advancedform.h" -#include "src/widget/form/settings/aboutform.h" -#include "src/widget/translator.h" #include "src/widget/contentlayout.h" +#include "src/widget/form/settings/aboutform.h" +#include "src/widget/form/settings/advancedform.h" +#include "src/widget/form/settings/avform.h" +#include "src/widget/form/settings/generalform.h" +#include "src/widget/form/settings/privacyform.h" +#include "src/widget/form/settings/userinterfaceform.h" +#include "src/widget/translator.h" +#include "src/widget/widget.h" SettingsWidget::SettingsWidget(QWidget* parent) : QWidget(parent, Qt::Window) @@ -49,10 +49,10 @@ SettingsWidget::SettingsWidget(QWidget* parent) UserInterfaceForm* uifrm = new UserInterfaceForm(this); PrivacyForm* pfrm = new PrivacyForm(); AVForm* avfrm = new AVForm(); - AdvancedForm *expfrm = new AdvancedForm(); - AboutForm *abtfrm = new AboutForm(); + AdvancedForm* expfrm = new AdvancedForm(); + AboutForm* abtfrm = new AboutForm(); - cfgForms = {{ gfrm, uifrm, pfrm, avfrm, expfrm, abtfrm }}; + cfgForms = {{gfrm, uifrm, pfrm, avfrm, expfrm, abtfrm}}; for (GenericForm* cfgForm : cfgForms) settingsWidgets->addTab(cfgForm, cfgForm->getFormIcon(), cfgForm->getFormName()); @@ -78,8 +78,7 @@ void SettingsWidget::showAbout() bool SettingsWidget::isShown() const { - if (settingsWidgets->isVisible()) - { + if (settingsWidgets->isVisible()) { settingsWidgets->window()->windowHandle()->alert(0); return true; } diff --git a/src/widget/form/settingswidget.h b/src/widget/form/settingswidget.h index 3a568df45..5bd5cbcbf 100644 --- a/src/widget/form/settingswidget.h +++ b/src/widget/form/settingswidget.h @@ -54,7 +54,7 @@ private: void retranslateUi(); private: - QTabWidget *settingsWidgets; + QTabWidget* settingsWidgets; std::array cfgForms; int currentIndex; }; diff --git a/src/widget/form/tabcompleter.cpp b/src/widget/form/tabcompleter.cpp index 905e2fadb..a21f1401b 100644 --- a/src/widget/form/tabcompleter.cpp +++ b/src/widget/form/tabcompleter.cpp @@ -22,8 +22,8 @@ #include "tabcompleter.h" -#include #include +#include #include "src/core/core.h" #include "src/group.h" @@ -39,8 +39,11 @@ const QString TabCompleter::nickSuffix = QString(": "); TabCompleter::TabCompleter(ChatTextEdit* msgEdit, Group* group) - : QObject{msgEdit}, msgEdit{msgEdit}, group{group}, - enabled{false}, lastCompletionLength{0} + : QObject{msgEdit} + , msgEdit{msgEdit} + , group{group} + , enabled{false} + , lastCompletionLength{0} { } @@ -50,7 +53,8 @@ TabCompleter::TabCompleter(ChatTextEdit* msgEdit, Group* group) inline QString html() const { return toHtml(); } inline int cursorPosition() const { return textCursor().position(); } inline void insert(const QString &newText) { insertPlainText(newText); } - inline void backspace() { keyPressEvent(new QKeyEvent(QEvent::KeyPress, Qt::Key_Backspace, Qt::NoModifier)); } + inline void backspace() { keyPressEvent(new QKeyEvent(QEvent::KeyPress, Qt::Key_Backspace, + Qt::NoModifier)); } */ void TabCompleter::buildCompletionList() @@ -59,16 +63,17 @@ void TabCompleter::buildCompletionList() completionMap.clear(); nextCompletion = completionMap.begin(); - // split the string on the given RE (not chars, nums or braces/brackets) and take the last section - QString tabAbbrev = msgEdit->toPlainText().left(msgEdit->textCursor().position()) - .section(QRegExp("[^\\w\\d\\$:@--_\\[\\]{}|`^.\\\\]"), -1, -1); + // split the string on the given RE (not chars, nums or braces/brackets) and take the last + // section + QString tabAbbrev = msgEdit->toPlainText() + .left(msgEdit->textCursor().position()) + .section(QRegExp("[^\\w\\d\\$:@--_\\[\\]{}|`^.\\\\]"), -1, -1); // that section is then used as the completion regex - QRegExp regex(QString("^[-_\\[\\]{}|`^.\\\\]*").append(QRegExp::escape(tabAbbrev)), Qt::CaseInsensitive); + QRegExp regex(QString("^[-_\\[\\]{}|`^.\\\\]*").append(QRegExp::escape(tabAbbrev)), + Qt::CaseInsensitive); - for (auto name : group->getPeerList()) - { - if (regex.indexIn(name) > -1) - { + for (auto name : group->getPeerList()) { + if (regex.indexIn(name) > -1) { SortableString lower = SortableString(name.toLower()); completionMap[lower] = name; } @@ -81,14 +86,12 @@ void TabCompleter::buildCompletionList() void TabCompleter::complete() { - if (!enabled) - { + if (!enabled) { buildCompletionList(); enabled = true; } - if (nextCompletion != completionMap.end()) - { + if (nextCompletion != completionMap.end()) { // clear previous completion auto cur = msgEdit->textCursor(); cur.setPosition(cur.selectionEnd()); @@ -104,16 +107,12 @@ void TabCompleter::complete() ++nextCompletion; // we're completing the first word of the line - if (msgEdit->textCursor().position() == lastCompletionLength) - { + if (msgEdit->textCursor().position() == lastCompletionLength) { msgEdit->insertPlainText(nickSuffix); lastCompletionLength += nickSuffix.length(); } - } - else - { // we're at the end of the list -> start over again - if (!completionMap.isEmpty()) - { + } else { // we're at the end of the list -> start over again + if (!completionMap.isEmpty()) { nextCompletion = completionMap.begin(); complete(); } @@ -126,7 +125,7 @@ void TabCompleter::reset() } // this determines the sort order -bool TabCompleter::SortableString::operator<(const SortableString &other) const +bool TabCompleter::SortableString::operator<(const SortableString& other) const { QString name = Core::getInstance()->getUsername(); if (this->contents == name) @@ -134,13 +133,15 @@ bool TabCompleter::SortableString::operator<(const SortableString &other) const else if (other.contents == name) return true; -/* QDateTime thisTime = thisUser->lastChannelActivity(_currentBufferId); + /* QDateTime thisTime = thisUser->lastChannelActivity(_currentBufferId); QDateTime thatTime = thatUser->lastChannelActivity(_currentBufferId); if (thisTime.isValid() || thatTime.isValid()) return thisTime > thatTime; -*/ // this could be a useful feature at some point +*/ // this could be a + // useful feature at + // some point return QString::localeAwareCompare(this->contents, other.contents) < 0; } diff --git a/src/widget/form/tabcompleter.h b/src/widget/form/tabcompleter.h index 4d03a1dac..4775dccfa 100644 --- a/src/widget/form/tabcompleter.h +++ b/src/widget/form/tabcompleter.h @@ -23,10 +23,10 @@ #ifndef TABCOMPLETER_H #define TABCOMPLETER_H -#include -#include #include "src/group.h" #include "src/widget/tool/chattextedit.h" +#include +#include class TabCompleter : public QObject { @@ -39,9 +39,13 @@ public slots: void reset(); private: - struct SortableString { - explicit SortableString(const QString &n) : contents{n} {} - bool operator<(const SortableString &other) const; + struct SortableString + { + explicit SortableString(const QString& n) + : contents{n} + { + } + bool operator<(const SortableString& other) const; QString contents; }; diff --git a/src/widget/friendlistlayout.cpp b/src/widget/friendlistlayout.cpp index e10dafdcb..acc0bda94 100644 --- a/src/widget/friendlistlayout.cpp +++ b/src/widget/friendlistlayout.cpp @@ -13,10 +13,10 @@ */ #include "friendlistlayout.h" +#include "friendlistwidget.h" +#include "friendwidget.h" #include "src/friend.h" #include "src/friendlist.h" -#include "friendwidget.h" -#include "friendlistwidget.h" #include FriendListLayout::FriendListLayout() @@ -51,8 +51,7 @@ void FriendListLayout::addFriendWidget(FriendWidget* w, Status s) friendOfflineLayout.removeSortedWidget(w); friendOnlineLayout.removeSortedWidget(w); - if (s == Status::Offline) - { + if (s == Status::Offline) { friendOfflineLayout.addSortedWidget(w); return; } @@ -60,7 +59,7 @@ void FriendListLayout::addFriendWidget(FriendWidget* w, Status s) friendOnlineLayout.addSortedWidget(w); } -void FriendListLayout::removeFriendWidget(FriendWidget *widget, Status s) +void FriendListLayout::removeFriendWidget(FriendWidget* widget, Status s) { if (s == Status::Offline) friendOfflineLayout.removeSortedWidget(widget); @@ -77,16 +76,14 @@ int FriendListLayout::indexOfFriendWidget(GenericChatItemWidget* widget, bool on void FriendListLayout::moveFriendWidgets(FriendListWidget* listWidget) { - while (!friendOnlineLayout.getLayout()->isEmpty()) - { + while (!friendOnlineLayout.getLayout()->isEmpty()) { QWidget* getWidget = friendOnlineLayout.getLayout()->takeAt(0)->widget(); FriendWidget* friendWidget = qobject_cast(getWidget); Friend* f = FriendList::findFriend(friendWidget->friendId); listWidget->moveWidget(friendWidget, f->getStatus(), false); } - while (!friendOfflineLayout.getLayout()->isEmpty()) - { + while (!friendOfflineLayout.getLayout()->isEmpty()) { QWidget* getWidget = friendOfflineLayout.getLayout()->takeAt(0)->widget(); FriendWidget* friendWidget = qobject_cast(getWidget); diff --git a/src/widget/friendlistlayout.h b/src/widget/friendlistlayout.h index 35d48016a..e7da6e7d9 100644 --- a/src/widget/friendlistlayout.h +++ b/src/widget/friendlistlayout.h @@ -15,9 +15,9 @@ #ifndef FRIENDLISTLAYOUT_H #define FRIENDLISTLAYOUT_H -#include -#include "src/core/corestructs.h" #include "genericchatitemlayout.h" +#include "src/core/corestructs.h" +#include class FriendWidget; class FriendListWidget; @@ -37,7 +37,8 @@ public: int friendTotalCount() const; bool hasChatrooms() const; - void searchChatrooms(const QString& searchString, bool hideOnline = false, bool hideOffline = false); + void searchChatrooms(const QString& searchString, bool hideOnline = false, + bool hideOffline = false); QLayout* getLayoutOnline() const; QLayout* getLayoutOffline() const; diff --git a/src/widget/friendlistwidget.cpp b/src/widget/friendlistwidget.cpp index 2ecd9435e..6bea6b4b4 100644 --- a/src/widget/friendlistwidget.cpp +++ b/src/widget/friendlistwidget.cpp @@ -18,18 +18,18 @@ */ #include "friendlistwidget.h" +#include "circlewidget.h" #include "friendlistlayout.h" +#include "friendwidget.h" +#include "groupwidget.h" +#include "widget.h" #include "src/friend.h" #include "src/friendlist.h" #include "src/persistence/settings.h" -#include "friendwidget.h" -#include "groupwidget.h" -#include "circlewidget.h" -#include "widget.h" -#include -#include #include #include +#include +#include #include #include @@ -75,8 +75,7 @@ Time getTime(const QDate& date) today = today.addDays(-today.day() + 1); // Go to the beginning of the month. - if (last7DaysWasLastMonth()) - { + if (last7DaysWasLastMonth()) { if (date >= today) return ThisMonth; @@ -118,7 +117,7 @@ qint64 timeUntilTomorrow() { QDateTime now = QDateTime::currentDateTime(); QDateTime tomorrow = now.addDays(1); // Tomorrow. - tomorrow.setTime(QTime()); // Midnight. + tomorrow.setTime(QTime()); // Midnight. return now.msecsTo(tomorrow); } @@ -153,22 +152,18 @@ FriendListWidget::FriendListWidget(Widget* parent, bool groupsOnTop) FriendListWidget::~FriendListWidget() { - if (activityLayout != nullptr) - { + if (activityLayout != nullptr) { QLayoutItem* item; - while ((item = activityLayout->takeAt(0)) != nullptr) - { + while ((item = activityLayout->takeAt(0)) != nullptr) { delete item->widget(); delete item; } delete activityLayout; } - if (circleLayout != nullptr) - { + if (circleLayout != nullptr) { QLayoutItem* item; - while ((item = circleLayout->getLayout()->takeAt(0)) != nullptr) - { + while ((item = circleLayout->getLayout()->takeAt(0)) != nullptr) { delete item->widget(); delete item; } @@ -183,14 +178,12 @@ void FriendListWidget::setMode(Mode mode) this->mode = mode; - if (mode == Name) - { + if (mode == Name) { circleLayout = new GenericChatItemLayout; circleLayout->getLayout()->setSpacing(0); circleLayout->getLayout()->setMargin(0); - for (int i = 0; i < Settings::getInstance().getCircleCount(); ++i) - { + for (int i = 0; i < Settings::getInstance().getCircleCount(); ++i) { addCircleWidget(i); CircleWidget::getFromID(i)->setVisible(false); } @@ -200,16 +193,12 @@ void FriendListWidget::setMode(Mode mode) CircleWidget::getFromID(i)->setVisible(true); int count = activityLayout ? activityLayout->count() : 0; - for (int i = 0; i < count; i++) - { + for (int i = 0; i < count; i++) { QWidget* widget = activityLayout->itemAt(i)->widget(); - CategoryWidget *categoryWidget = qobject_cast(widget); - if (categoryWidget) - { + CategoryWidget* categoryWidget = qobject_cast(widget); + if (categoryWidget) { categoryWidget->moveFriendWidgets(this); - } - else - { + } else { qWarning() << "Unexpected widget"; } } @@ -219,11 +208,9 @@ void FriendListWidget::setMode(Mode mode) listLayout->addLayout(circleLayout->getLayout()); onGroupchatPositionChanged(groupsOnTop); - if (activityLayout != nullptr) - { + if (activityLayout != nullptr) { QLayoutItem* item; - while ((item = activityLayout->takeAt(0)) != nullptr) - { + while ((item = activityLayout->takeAt(0)) != nullptr) { delete item->widget(); delete item; } @@ -232,9 +219,7 @@ void FriendListWidget::setMode(Mode mode) } reDraw(); - } - else if (mode == Activity) - { + } else if (mode == Activity) { activityLayout = new QVBoxLayout(); CategoryWidget* categoryToday = new CategoryWidget(this); @@ -251,10 +236,11 @@ void FriendListWidget::setMode(Mode mode) activityLayout->addWidget(categoryLastWeek); QDate currentDate = QDate::currentDate(); - //if (last7DaysWasLastMonth()) + // if (last7DaysWasLastMonth()) { CategoryWidget* categoryThisMonth = new CategoryWidget(this); - categoryThisMonth->setName(tr("This month", "Category for sorting friends by activity")); + categoryThisMonth->setName( + tr("This month", "Category for sorting friends by activity")); activityLayout->addWidget(categoryThisMonth); categoryThisMonth->setVisible(last7DaysWasLastMonth()); @@ -262,7 +248,7 @@ void FriendListWidget::setMode(Mode mode) currentDate = currentDate.addMonths(-1); } - QLocale *ql = new QLocale(Settings::getInstance().getTranslation()); + QLocale* ql = new QLocale(Settings::getInstance().getTranslation()); CategoryWidget* categoryLast1Month = new CategoryWidget(this); categoryLast1Month->setName(ql->monthName(currentDate.month())); @@ -289,7 +275,8 @@ void FriendListWidget::setMode(Mode mode) activityLayout->addWidget(categoryLast5Month); CategoryWidget* categoryOlder = new CategoryWidget(this); - categoryOlder->setName(tr("Older than 6 Months", "Category for sorting friends by activity")); + categoryOlder->setName( + tr("Older than 6 Months", "Category for sorting friends by activity")); activityLayout->addWidget(categoryOlder); CategoryWidget* categoryNever = new CategoryWidget(this); @@ -303,22 +290,20 @@ void FriendListWidget::setMode(Mode mode) moveFriends(listLayout->getLayoutOnline()); moveFriends(circleLayout->getLayout()); - for (int i = 0; i < activityLayout->count(); ++i) - { - CategoryWidget* categoryWidget = qobject_cast(activityLayout->itemAt(i)->widget()); + for (int i = 0; i < activityLayout->count(); ++i) { + CategoryWidget* categoryWidget = + qobject_cast(activityLayout->itemAt(i)->widget()); categoryWidget->setVisible(categoryWidget->hasChatrooms()); } listLayout->removeItem(listLayout->getLayoutOnline()); listLayout->removeItem(listLayout->getLayoutOffline()); - if (circleLayout != nullptr) - { + if (circleLayout != nullptr) { listLayout->removeItem(circleLayout->getLayout()); QLayoutItem* item; - while ((item = circleLayout->getLayout()->takeAt(0)) != nullptr) - { + while ((item = circleLayout->getLayout()->takeAt(0)) != nullptr) { delete item->widget(); delete item; } @@ -334,19 +319,15 @@ void FriendListWidget::setMode(Mode mode) void FriendListWidget::moveFriends(QLayout* layout) { - for (int i = 0; i < layout->count(); i++) - { + for (int i = 0; i < layout->count(); i++) { QWidget* widget = layout->itemAt(i)->widget(); - FriendWidget *friendWidget = qobject_cast(widget); - CircleWidget *circleWidget = qobject_cast(widget); - if (circleWidget) - { + FriendWidget* friendWidget = qobject_cast(widget); + CircleWidget* circleWidget = qobject_cast(widget); + if (circleWidget) { circleWidget->moveFriendWidgets(this); - } - else if (friendWidget) - { + } else if (friendWidget) { int friendId = friendWidget->friendId; - Friend *contact = FriendList::findFriend(friendId); + Friend* contact = FriendList::findFriend(friendId); QDate activityDate = getDateFriend(contact); Time time = getTime(activityDate); @@ -354,7 +335,6 @@ void FriendListWidget::moveFriends(QLayout* layout) CategoryWidget* categoryWidget = qobject_cast(w); categoryWidget->addFriendWidget(friendWidget, contact->getStatus()); } - } } @@ -381,20 +361,17 @@ void FriendListWidget::addFriendWidget(FriendWidget* w, Status s, int circleInde void FriendListWidget::removeFriendWidget(FriendWidget* w) { Friend* contact = FriendList::findFriend(w->friendId); - if (mode == Activity) - { + if (mode == Activity) { QDate activityDate = getDateFriend(contact); Time time = getTime(activityDate); - CategoryWidget* categoryWidget = qobject_cast(activityLayout->itemAt(time)->widget()); + CategoryWidget* categoryWidget = + qobject_cast(activityLayout->itemAt(time)->widget()); categoryWidget->removeFriendWidget(w, contact->getStatus()); categoryWidget->setVisible(categoryWidget->hasChatrooms()); - } - else - { + } else { int id = Settings::getInstance().getFriendCircleID(contact->getPublicKey()); CircleWidget* circleWidget = CircleWidget::getFromID(id); - if (circleWidget != nullptr) - { + if (circleWidget != nullptr) { circleWidget->removeFriendWidget(w, contact->getStatus()); Widget::getInstance()->searchCircle(circleWidget); } @@ -409,10 +386,8 @@ void FriendListWidget::addCircleWidget(int id) void FriendListWidget::addCircleWidget(FriendWidget* friendWidget) { CircleWidget* circleWidget = createCircleWidget(); - if (circleWidget != nullptr) - { - if (friendWidget != nullptr) - { + if (circleWidget != nullptr) { + if (friendWidget != nullptr) { Friend* f = FriendList::findFriend(friendWidget->friendId); ToxPk toxPk = f->getPublicKey(); int circleId = Settings::getInstance().getFriendCircleID(toxPk); @@ -423,7 +398,6 @@ void FriendListWidget::addCircleWidget(FriendWidget* friendWidget) if (circleOriginal != nullptr) Widget::getInstance()->searchCircle(circleOriginal); - } Widget::getInstance()->searchCircle(circleWidget); @@ -440,38 +414,36 @@ void FriendListWidget::removeCircleWidget(CircleWidget* widget) widget->deleteLater(); } -void FriendListWidget::searchChatrooms(const QString &searchString, bool hideOnline, bool hideOffline, bool hideGroups) +void FriendListWidget::searchChatrooms(const QString& searchString, bool hideOnline, + bool hideOffline, bool hideGroups) { groupLayout.search(searchString, hideGroups); listLayout->searchChatrooms(searchString, hideOnline, hideOffline); - if (circleLayout != nullptr) - { - for (int i = 0; i != circleLayout->getLayout()->count(); ++i) - { - CircleWidget* circleWidget = static_cast(circleLayout->getLayout()->itemAt(i)->widget()); + if (circleLayout != nullptr) { + for (int i = 0; i != circleLayout->getLayout()->count(); ++i) { + CircleWidget* circleWidget = + static_cast(circleLayout->getLayout()->itemAt(i)->widget()); circleWidget->search(searchString, true, hideOnline, hideOffline); } - } - else if (activityLayout != nullptr) - { - for (int i = 0; i != activityLayout->count(); ++i) - { - CategoryWidget* categoryWidget = static_cast(activityLayout->itemAt(i)->widget()); + } else if (activityLayout != nullptr) { + for (int i = 0; i != activityLayout->count(); ++i) { + CategoryWidget* categoryWidget = + static_cast(activityLayout->itemAt(i)->widget()); categoryWidget->search(searchString, true, hideOnline, hideOffline); categoryWidget->setVisible(categoryWidget->hasChatrooms()); } } } -void FriendListWidget::renameGroupWidget(GroupWidget* groupWidget, const QString &newName) +void FriendListWidget::renameGroupWidget(GroupWidget* groupWidget, const QString& newName) { groupLayout.removeSortedWidget(groupWidget); groupWidget->setName(newName); groupLayout.addSortedWidget(groupWidget); } -void FriendListWidget::renameCircleWidget(CircleWidget* circleWidget, const QString &newName) +void FriendListWidget::renameCircleWidget(CircleWidget* circleWidget, const QString& newName) { circleLayout->removeSortedWidget(circleWidget); circleWidget->setName(newName); @@ -503,40 +475,35 @@ void FriendListWidget::cycleContacts(GenericChatroomWidget* activeChatroomWidget int index = -1; FriendWidget* friendWidget = qobject_cast(activeChatroomWidget); - if (mode == Activity) - { + if (mode == Activity) { if (friendWidget == nullptr) return; QDate activityDate = getDateFriend(FriendList::findFriend(friendWidget->friendId)); index = getTime(activityDate); - CategoryWidget* categoryWidget = qobject_cast(activityLayout->itemAt(index)->widget()); + CategoryWidget* categoryWidget = + qobject_cast(activityLayout->itemAt(index)->widget()); if (categoryWidget == nullptr || categoryWidget->cycleContacts(friendWidget, forward)) return; index += forward ? 1 : -1; - for (;;) - { + for (;;) { // Bounds checking. - if (index < Today) - { + if (index < Today) { index = Never; continue; - } - else if (index > Never) - { + } else if (index > Never) { index = Today; continue; } - CategoryWidget* categoryWidget = qobject_cast(activityLayout->itemAt(index)->widget()); + CategoryWidget* categoryWidget = + qobject_cast(activityLayout->itemAt(index)->widget()); - if (categoryWidget != nullptr) - { - if (!categoryWidget->cycleContacts(forward)) - { + if (categoryWidget != nullptr) { + if (!categoryWidget->cycleContacts(forward)) { // Skip empty or finished categories. index += forward ? 1 : -1; continue; @@ -552,86 +519,69 @@ void FriendListWidget::cycleContacts(GenericChatroomWidget* activeChatroomWidget QLayout* currentLayout = nullptr; CircleWidget* circleWidget = nullptr; - if (friendWidget != nullptr) - { - circleWidget = CircleWidget::getFromID(Settings::getInstance().getFriendCircleID(FriendList::findFriend(friendWidget->friendId)->getPublicKey())); - if (circleWidget != nullptr) - { + if (friendWidget != nullptr) { + circleWidget = CircleWidget::getFromID(Settings::getInstance().getFriendCircleID( + FriendList::findFriend(friendWidget->friendId)->getPublicKey())); + if (circleWidget != nullptr) { if (circleWidget->cycleContacts(friendWidget, forward)) return; index = circleLayout->indexOfSortedWidget(circleWidget); currentLayout = circleLayout->getLayout(); - } - else - { + } else { currentLayout = listLayout->getLayoutOnline(); index = listLayout->indexOfFriendWidget(friendWidget, true); - if (index == -1) - { + if (index == -1) { currentLayout = listLayout->getLayoutOffline(); index = listLayout->indexOfFriendWidget(friendWidget, false); } } - } - else - { + } else { GroupWidget* groupWidget = qobject_cast(activeChatroomWidget); - if (groupWidget != nullptr) - { + if (groupWidget != nullptr) { currentLayout = groupLayout.getLayout(); index = groupLayout.indexOfSortedWidget(groupWidget); - } - else - { + } else { return; }; } index += forward ? 1 : -1; - for (;;) - { + for (;;) { // Bounds checking. - if (index < 0) - { + if (index < 0) { currentLayout = nextLayout(currentLayout, forward); index = currentLayout->count() - 1; continue; - } - else if (index >= currentLayout->count()) - { + } else if (index >= currentLayout->count()) { currentLayout = nextLayout(currentLayout, forward); index = 0; continue; } // Go to the actual next index. - if (currentLayout == listLayout->getLayoutOnline() || currentLayout == listLayout->getLayoutOffline() || currentLayout == groupLayout.getLayout()) - { - GenericChatroomWidget* chatWidget = qobject_cast(currentLayout->itemAt(index)->widget()); + if (currentLayout == listLayout->getLayoutOnline() + || currentLayout == listLayout->getLayoutOffline() + || currentLayout == groupLayout.getLayout()) { + GenericChatroomWidget* chatWidget = + qobject_cast(currentLayout->itemAt(index)->widget()); if (chatWidget != nullptr) emit chatWidget->chatroomWidgetClicked(chatWidget); return; - } - else if (currentLayout == circleLayout->getLayout()) - { + } else if (currentLayout == circleLayout->getLayout()) { circleWidget = qobject_cast(currentLayout->itemAt(index)->widget()); - if (circleWidget != nullptr) - { - if (!circleWidget->cycleContacts(forward)) - { + if (circleWidget != nullptr) { + if (!circleWidget->cycleContacts(forward)) { // Skip empty or finished circles. index += forward ? 1 : -1; continue; } } return; - } - else - { + } else { return; } } @@ -648,8 +598,8 @@ void FriendListWidget::dragEnterEvent(QDragEnterEvent* event) void FriendListWidget::dropEvent(QDropEvent* event) { // Check, that the element is dropped from qTox - QObject *o = event->source(); - FriendWidget *widget = qobject_cast(o); + QObject* o = event->source(); + FriendWidget* widget = qobject_cast(o); if (!widget) return; @@ -671,8 +621,7 @@ void FriendListWidget::dropEvent(QDropEvent* event) void FriendListWidget::dayTimeout() { - if (mode == Activity) - { + if (mode == Activity) { setMode(Name); setMode(Activity); // Refresh all. } @@ -682,14 +631,12 @@ void FriendListWidget::dayTimeout() void FriendListWidget::moveWidget(FriendWidget* widget, Status s, bool add) { - if (mode == Name) - { + if (mode == Name) { Friend* f = FriendList::findFriend(widget->friendId); int circleId = Settings::getInstance().getFriendCircleID(f->getPublicKey()); CircleWidget* circleWidget = CircleWidget::getFromID(circleId); - if (circleWidget == nullptr || add) - { + if (circleWidget == nullptr || add) { if (circleId != -1) Settings::getInstance().setFriendCircleID(f->getPublicKey(), -1); @@ -698,9 +645,7 @@ void FriendListWidget::moveWidget(FriendWidget* widget, Status s, bool add) } circleWidget->addFriendWidget(widget, s); - } - else - { + } else { Friend* contact = FriendList::findFriend(widget->friendId); QDate activityDate = getDateFriend(contact); Time time = getTime(activityDate); @@ -716,7 +661,8 @@ void FriendListWidget::updateActivityDate(const QDate& date) if (mode != Activity) return; - CategoryWidget* categoryWidget = static_cast(activityLayout->itemAt(getTime(date))->widget()); + CategoryWidget* categoryWidget = + static_cast(activityLayout->itemAt(getTime(date))->widget()); categoryWidget->updateStatus(); categoryWidget->setVisible(categoryWidget->hasChatrooms()); @@ -727,7 +673,7 @@ void FriendListWidget::reDraw() { hide(); show(); - resize(QSize()); //lifehack + resize(QSize()); // lifehack } CircleWidget* FriendListWidget::createCircleWidget(int id) @@ -752,59 +698,44 @@ CircleWidget* FriendListWidget::createCircleWidget(int id) QLayout* FriendListWidget::nextLayout(QLayout* layout, bool forward) const { - if (layout == groupLayout.getLayout()) - { - if (forward) - { + if (layout == groupLayout.getLayout()) { + if (forward) { if (groupsOnTop) return listLayout->getLayoutOnline(); return listLayout->getLayoutOffline(); - } - else - { + } else { if (groupsOnTop) return circleLayout->getLayout(); return listLayout->getLayoutOnline(); } - } - else if (layout == listLayout->getLayoutOnline()) - { - if (forward) - { + } else if (layout == listLayout->getLayoutOnline()) { + if (forward) { if (groupsOnTop) return listLayout->getLayoutOffline(); return groupLayout.getLayout(); - } - else - { + } else { if (groupsOnTop) return groupLayout.getLayout(); return circleLayout->getLayout(); } - } - else if (layout == listLayout->getLayoutOffline()) - { + } else if (layout == listLayout->getLayoutOffline()) { if (forward) return circleLayout->getLayout(); else if (groupsOnTop) return listLayout->getLayoutOnline(); return groupLayout.getLayout(); - } - else if (layout == circleLayout->getLayout()) - { - if (forward) - { + } else if (layout == circleLayout->getLayout()) { + if (forward) { if (groupsOnTop) return groupLayout.getLayout(); return listLayout->getLayoutOnline(); - } - else + } else return listLayout->getLayoutOffline(); } return nullptr; diff --git a/src/widget/friendlistwidget.h b/src/widget/friendlistwidget.h index a510f58be..3d7a1ac87 100644 --- a/src/widget/friendlistwidget.h +++ b/src/widget/friendlistwidget.h @@ -20,9 +20,9 @@ #ifndef FRIENDLISTWIDGET_H #define FRIENDLISTWIDGET_H -#include -#include "src/core/corestructs.h" #include "genericchatitemlayout.h" +#include "src/core/corestructs.h" +#include class QVBoxLayout; class QGridLayout; @@ -55,7 +55,8 @@ public: void addCircleWidget(int id); void addCircleWidget(FriendWidget* widget = nullptr); void removeCircleWidget(CircleWidget* widget); - void searchChatrooms(const QString &searchString, bool hideOnline = false, bool hideOffline = false, bool hideGroups = false); + void searchChatrooms(const QString& searchString, bool hideOnline = false, + bool hideOffline = false, bool hideGroups = false); void cycleContacts(GenericChatroomWidget* activeChatroomWidget, bool forward); diff --git a/src/widget/friendwidget.cpp b/src/widget/friendwidget.cpp index d68e69679..7ff027960 100644 --- a/src/widget/friendwidget.cpp +++ b/src/widget/friendwidget.cpp @@ -88,7 +88,7 @@ void FriendWidget::contextMenuEvent(QContextMenuEvent* event) * * Context menu handler. Always should be called to FriendWidget from FriendList */ -void FriendWidget::onContextMenuCalled(QContextMenuEvent *event) +void FriendWidget::onContextMenuCalled(QContextMenuEvent* event) { if (!active) setBackgroundRole(QPalette::Highlight); @@ -112,72 +112,75 @@ void FriendWidget::onContextMenuCalled(QContextMenuEvent *event) removeChatWindow = menu.addAction(tr("Remove chat from this window")); menu.addSeparator(); - QMenu* inviteMenu = menu.addMenu(tr("Invite to group","Menu to invite a friend to a groupchat")); + QMenu* inviteMenu = + menu.addMenu(tr("Invite to group", "Menu to invite a friend to a groupchat")); inviteMenu->setEnabled(getFriend()->getStatus() != Status::Offline); QAction* newGroupAction = inviteMenu->addAction(tr("To new group")); inviteMenu->addSeparator(); QMap groupActions; - for (Group* group : GroupList::getAllGroups()) - { + for (Group* group : GroupList::getAllGroups()) { int maxNameLen = 30; QString name = group->getGroupWidget()->getName(); - if ( name.length() > maxNameLen ) - { + if (name.length() > maxNameLen) { name = name.left(maxNameLen).trimmed() + ".."; } QAction* groupAction = inviteMenu->addAction(tr("Invite to group '%1'").arg(name)); - groupActions[groupAction] = group; + groupActions[groupAction] = group; } - int circleId = Settings::getInstance().getFriendCircleID(FriendList::findFriend(friendId)->getPublicKey()); - CircleWidget *circleWidget = CircleWidget::getFromID(circleId); + int circleId = + Settings::getInstance().getFriendCircleID(FriendList::findFriend(friendId)->getPublicKey()); + CircleWidget* circleWidget = CircleWidget::getFromID(circleId); QMenu* circleMenu = nullptr; QAction* newCircleAction = nullptr; - QAction *removeCircleAction = nullptr; + QAction* removeCircleAction = nullptr; QMap circleActions; - FriendListWidget *friendList; + FriendListWidget* friendList; if (circleWidget == nullptr) friendList = qobject_cast(this->parentWidget()); else friendList = qobject_cast(circleWidget->parentWidget()); - circleMenu = menu.addMenu(tr("Move to circle...", "Menu to move a friend into a different circle")); + circleMenu = + menu.addMenu(tr("Move to circle...", "Menu to move a friend into a different circle")); newCircleAction = circleMenu->addAction(tr("To new circle")); if (circleId != -1) - removeCircleAction = circleMenu->addAction(tr("Remove from circle '%1'").arg(Settings::getInstance().getCircleName(circleId))); + removeCircleAction = circleMenu->addAction( + tr("Remove from circle '%1'").arg(Settings::getInstance().getCircleName(circleId))); circleMenu->addSeparator(); QList circleActionList; - for (int i = 0; i < Settings::getInstance().getCircleCount(); ++i) - { - if (i != circleId) - { - circleActionList.push_back(new QAction(tr("Move to circle \"%1\"").arg(Settings::getInstance().getCircleName(i)), circleMenu)); + for (int i = 0; i < Settings::getInstance().getCircleCount(); ++i) { + if (i != circleId) { + circleActionList.push_back( + new QAction(tr("Move to circle \"%1\"").arg(Settings::getInstance().getCircleName(i)), + circleMenu)); circleActions[circleActionList.back()] = i; } } - std::sort(circleActionList.begin(), circleActionList.end(), [](const QAction* lhs, const QAction* rhs) -> bool - { - QCollator collator; - collator.setNumericMode(true); - return collator.compare(lhs->text(), rhs->text()) < 0; - }); + std::sort(circleActionList.begin(), circleActionList.end(), + [](const QAction* lhs, const QAction* rhs) -> bool { + QCollator collator; + collator.setNumericMode(true); + return collator.compare(lhs->text(), rhs->text()) < 0; + }); circleMenu->addActions(circleActionList); QAction* setAlias = menu.addAction(tr("Set alias...")); menu.addSeparator(); - QAction* autoAccept = menu.addAction(tr("Auto accept files from this friend", "context menu entry")); + QAction* autoAccept = + menu.addAction(tr("Auto accept files from this friend", "context menu entry")); autoAccept->setCheckable(true); autoAccept->setChecked(!dir.isEmpty()); menu.addSeparator(); @@ -185,7 +188,8 @@ void FriendWidget::onContextMenuCalled(QContextMenuEvent *event) QAction* removeFriendAction = nullptr; if (contentDialog == nullptr || !contentDialog->hasFriendWidget(friendId, this)) - removeFriendAction = menu.addAction(tr("Remove friend", "Menu to remove the friend from our friendlist")); + removeFriendAction = + menu.addAction(tr("Remove friend", "Menu to remove the friend from our friendlist")); menu.addSeparator(); QAction* aboutWindow = menu.addAction(tr("Show details")); @@ -200,56 +204,38 @@ void FriendWidget::onContextMenuCalled(QContextMenuEvent *event) if (!selectedItem) return; - if (selectedItem == setAlias) - { + if (selectedItem == setAlias) { nameLabel->editBegin(); - } - else if (selectedItem == removeFriendAction) - { + } else if (selectedItem == removeFriendAction) { emit removeFriend(friendId); - } - else if (selectedItem == openChatWindow) - { + } else if (selectedItem == openChatWindow) { emit chatroomWidgetClicked(this, true); - } - else if (selectedItem == removeChatWindow) - { + } else if (selectedItem == removeChatWindow) { ContentDialog* contentDialog = ContentDialog::getFriendDialog(friendId); contentDialog->removeFriend(friendId); - } - else if (selectedItem == autoAccept) - { - if (!autoAccept->isChecked()) - { + } else if (selectedItem == autoAccept) { + if (!autoAccept->isChecked()) { qDebug() << "not checked"; dir = QDir::homePath(); autoAccept->setChecked(false); Settings::getInstance().setAutoAcceptDir(id, ""); - } - else if (autoAccept->isChecked()) - { - dir = QFileDialog::getExistingDirectory( - 0, tr("Choose an auto accept directory", "popup title"), - dir, QFileDialog::DontUseNativeDialog); + } else if (autoAccept->isChecked()) { + dir = QFileDialog::getExistingDirectory(0, tr("Choose an auto accept directory", + "popup title"), + dir, QFileDialog::DontUseNativeDialog); autoAccept->setChecked(true); qDebug() << "Setting auto accept dir for" << friendId << "to" << dir; Settings::getInstance().setAutoAcceptDir(id, dir); } - } - else if (selectedItem == aboutWindow) - { - AboutUser *aboutUser = new AboutUser(id, Widget::getInstance()); + } else if (selectedItem == aboutWindow) { + AboutUser* aboutUser = new AboutUser(id, Widget::getInstance()); aboutUser->setFriend(FriendList::findFriend(friendId)); aboutUser->show(); - } - else if (selectedItem == newGroupAction) - { + } else if (selectedItem == newGroupAction) { int groupId = Core::getInstance()->createGroup(); Core::getInstance()->groupInviteFriend(friendId, groupId); - } - else if (selectedItem == newCircleAction) - { + } else if (selectedItem == newCircleAction) { if (circleWidget != nullptr) circleWidget->updateStatus(); @@ -257,43 +243,32 @@ void FriendWidget::onContextMenuCalled(QContextMenuEvent *event) friendList->addCircleWidget(this); else Settings::getInstance().setFriendCircleID(id, Settings::getInstance().addCircle()); - } - else if (groupActions.contains(selectedItem)) - { + } else if (groupActions.contains(selectedItem)) { Group* group = groupActions[selectedItem]; Core::getInstance()->groupInviteFriend(friendId, group->getGroupId()); - } - else if (removeCircleAction != nullptr && selectedItem == removeCircleAction) - { + } else if (removeCircleAction != nullptr && selectedItem == removeCircleAction) { if (friendList) friendList->moveWidget(this, FriendList::findFriend(friendId)->getStatus(), true); else Settings::getInstance().setFriendCircleID(id, -1); - if (circleWidget) - { + if (circleWidget) { circleWidget->updateStatus(); Widget::getInstance()->searchCircle(circleWidget); } - } - else if (circleActions.contains(selectedItem)) - { + } else if (circleActions.contains(selectedItem)) { CircleWidget* circle = CircleWidget::getFromID(circleActions[selectedItem]); - if (circle) - { + if (circle) { circle->addFriendWidget(this, FriendList::findFriend(friendId)->getStatus()); circle->setExpanded(true); Widget::getInstance()->searchCircle(circle); Settings::getInstance().savePersonal(); - } - else - { + } else { Settings::getInstance().setFriendCircleID(id, circleActions[selectedItem]); } - if (circleWidget) - { + if (circleWidget) { circleWidget->updateStatus(); Widget::getInstance()->searchCircle(circleWidget); } @@ -338,9 +313,9 @@ void FriendWidget::updateStatusLight() else if (status == Status::Offline && f->getEventFlag()) statusPic.setPixmap(QPixmap(":img/status/dot_offline_notification.svg")); - if (f->getEventFlag()) - { - CircleWidget* circleWidget = CircleWidget::getFromID(Settings::getInstance().getFriendCircleID(FriendList::findFriend(friendId)->getPublicKey())); + if (f->getEventFlag()) { + CircleWidget* circleWidget = CircleWidget::getFromID(Settings::getInstance().getFriendCircleID( + FriendList::findFriend(friendId)->getPublicKey())); if (circleWidget != nullptr) circleWidget->setExpanded(true); @@ -376,10 +351,11 @@ Friend* FriendWidget::getFriend() const return FriendList::findFriend(friendId); } -void FriendWidget::search(const QString &searchString, bool hide) +void FriendWidget::search(const QString& searchString, bool hide) { searchName(searchString, hide); - CircleWidget* circleWidget = CircleWidget::getFromID(Settings::getInstance().getFriendCircleID(FriendList::findFriend(friendId)->getPublicKey())); + CircleWidget* circleWidget = CircleWidget::getFromID( + Settings::getInstance().getFriendCircleID(FriendList::findFriend(friendId)->getPublicKey())); if (circleWidget != nullptr) circleWidget->search(searchString); } @@ -424,7 +400,7 @@ void FriendWidget::onAvatarRemoved(int FriendId) avatar->setPixmap(QPixmap(":/img/contact.svg")); } -void FriendWidget::mousePressEvent(QMouseEvent *ev) +void FriendWidget::mousePressEvent(QMouseEvent* ev) { if (ev->button() == Qt::LeftButton) dragStartPos = ev->pos(); @@ -432,13 +408,12 @@ void FriendWidget::mousePressEvent(QMouseEvent *ev) GenericChatroomWidget::mousePressEvent(ev); } -void FriendWidget::mouseMoveEvent(QMouseEvent *ev) +void FriendWidget::mouseMoveEvent(QMouseEvent* ev) { if (!(ev->buttons() & Qt::LeftButton)) return; - if ((dragStartPos - ev->pos()).manhattanLength() > QApplication::startDragDistance()) - { + if ((dragStartPos - ev->pos()).manhattanLength() > QApplication::startDragDistance()) { QMimeData* mdata = new QMimeData; mdata->setText(getFriend()->getPublicKey().toString()); diff --git a/src/widget/friendwidget.h b/src/widget/friendwidget.h index dd1769090..dd7f482d4 100644 --- a/src/widget/friendwidget.h +++ b/src/widget/friendwidget.h @@ -38,19 +38,19 @@ public: QString getStatusString() const override final; Friend* getFriend() const override final; - void search(const QString &searchString, bool hide = false); + void search(const QString& searchString, bool hide = false); signals: void friendWidgetClicked(FriendWidget* widget); void removeFriend(int friendId); void copyFriendIdToClipboard(int friendId); - void contextMenuCalled(QContextMenuEvent * event); + void contextMenuCalled(QContextMenuEvent* event); public slots: void onAvatarChange(int FriendId, const QPixmap& pic); void onAvatarRemoved(int FriendId); void setAlias(const QString& alias); - void onContextMenuCalled(QContextMenuEvent * event); + void onContextMenuCalled(QContextMenuEvent* event); protected: virtual void mousePressEvent(QMouseEvent* ev) override; diff --git a/src/widget/genericchatitemlayout.cpp b/src/widget/genericchatitemlayout.cpp index 07c9afc58..1b2ae9c7a 100644 --- a/src/widget/genericchatitemlayout.cpp +++ b/src/widget/genericchatitemlayout.cpp @@ -33,7 +33,8 @@ GenericChatItemLayout::~GenericChatItemLayout() delete layout; } -void GenericChatItemLayout::addSortedWidget(GenericChatItemWidget* widget, int stretch, Qt::Alignment alignment) +void GenericChatItemLayout::addSortedWidget(GenericChatItemWidget* widget, int stretch, + Qt::Alignment alignment) { int closest = indexOfClosestSortedWidget(widget); layout->insertWidget(closest, widget, stretch, alignment); @@ -49,7 +50,8 @@ int GenericChatItemLayout::indexOfSortedWidget(GenericChatItemWidget* widget) co if (index >= layout->count()) return -1; - GenericChatItemWidget* atMid = qobject_cast(layout->itemAt(index)->widget()); + GenericChatItemWidget* atMid = + qobject_cast(layout->itemAt(index)->widget()); assert(atMid != nullptr); if (atMid == widget) @@ -73,18 +75,19 @@ void GenericChatItemLayout::removeSortedWidget(GenericChatItemWidget* widget) if (layout->itemAt(index) == nullptr) return; - GenericChatItemWidget* atMid = qobject_cast(layout->itemAt(index)->widget()); + GenericChatItemWidget* atMid = + qobject_cast(layout->itemAt(index)->widget()); assert(atMid != nullptr); if (atMid == widget) layout->removeWidget(widget); } -void GenericChatItemLayout::search(const QString &searchString, bool hideAll) +void GenericChatItemLayout::search(const QString& searchString, bool hideAll) { - for (int index = 0; index < layout->count(); ++index) - { - GenericChatItemWidget* widgetAt = qobject_cast(layout->itemAt(index)->widget()); + for (int index = 0; index < layout->count(); ++index) { + GenericChatItemWidget* widgetAt = + qobject_cast(layout->itemAt(index)->widget()); assert(widgetAt != nullptr); widgetAt->searchName(searchString, hideAll); @@ -100,10 +103,10 @@ int GenericChatItemLayout::indexOfClosestSortedWidget(GenericChatItemWidget* wid { // Binary search: Deferred test of equality. int min = 0, max = layout->count(); - while (min < max) - { + while (min < max) { int mid = (max - min) / 2 + min; - GenericChatItemWidget* atMid = qobject_cast(layout->itemAt(mid)->widget()); + GenericChatItemWidget* atMid = + qobject_cast(layout->itemAt(mid)->widget()); assert(atMid != nullptr); bool lessThan = false; diff --git a/src/widget/genericchatitemlayout.h b/src/widget/genericchatitemlayout.h index 9577af1c2..bb781a750 100644 --- a/src/widget/genericchatitemlayout.h +++ b/src/widget/genericchatitemlayout.h @@ -23,7 +23,6 @@ class GenericChatItemWidget; class GenericChatItemLayout { public: - GenericChatItemLayout(); ~GenericChatItemLayout(); @@ -31,7 +30,7 @@ public: int indexOfSortedWidget(GenericChatItemWidget* widget) const; bool existsSortedWidget(GenericChatItemWidget* widget) const; void removeSortedWidget(GenericChatItemWidget* widget); - void search(const QString &searchString, bool hideAll = false); + void search(const QString& searchString, bool hideAll = false); QLayout* getLayout() const; diff --git a/src/widget/genericchatitemwidget.cpp b/src/widget/genericchatitemwidget.cpp index e58fb2874..a404b878c 100644 --- a/src/widget/genericchatitemwidget.cpp +++ b/src/widget/genericchatitemwidget.cpp @@ -18,13 +18,14 @@ */ #include "genericchatitemwidget.h" -#include "src/widget/style.h" #include "src/persistence/settings.h" +#include "src/widget/style.h" #include "src/widget/tool/croppinglabel.h" #include GenericChatItemWidget::GenericChatItemWidget(QWidget* parent) - : QFrame(parent), compact(false) + : QFrame(parent) + , compact(false) { setProperty("compact", Settings::getInstance().getCompactLayout()); @@ -48,7 +49,7 @@ QString GenericChatItemWidget::getName() const return nameLabel->fullText(); } -void GenericChatItemWidget::searchName(const QString &searchString, bool hide) +void GenericChatItemWidget::searchName(const QString& searchString, bool hide) { setVisible(!hide && getName().contains(searchString, Qt::CaseInsensitive)); } diff --git a/src/widget/genericchatitemwidget.h b/src/widget/genericchatitemwidget.h index 94bc99526..34aac8e47 100644 --- a/src/widget/genericchatitemwidget.h +++ b/src/widget/genericchatitemwidget.h @@ -43,7 +43,7 @@ public: QString getName() const; - void searchName(const QString &searchString, bool hideAll); + void searchName(const QString& searchString, bool hideAll); Q_PROPERTY(bool compact READ isCompact WRITE setCompact) diff --git a/src/widget/genericchatroomwidget.cpp b/src/widget/genericchatroomwidget.cpp index 56adde55c..7c20d2efa 100644 --- a/src/widget/genericchatroomwidget.cpp +++ b/src/widget/genericchatroomwidget.cpp @@ -18,22 +18,23 @@ */ #include "genericchatroomwidget.h" -#include "src/widget/style.h" -#include "src/persistence/settings.h" #include "maskablepixmapwidget.h" +#include "src/persistence/settings.h" +#include "src/widget/style.h" #include "src/widget/tool/croppinglabel.h" #include #include GenericChatroomWidget::GenericChatroomWidget(QWidget* parent) - : GenericChatItemWidget(parent), active{false} + : GenericChatItemWidget(parent) + , active{false} { // avatar QSize size; if (isCompact()) - size = QSize(20,20); + size = QSize(20, 20); else - size = QSize(40,40); + size = QSize(40, 40); avatar = new MaskablePixmapWidget(this, size, ":/img/avatar_mask.svg"); @@ -45,8 +46,7 @@ GenericChatroomWidget::GenericChatroomWidget(QWidget* parent) nameLabel->setForegroundRole(QPalette::WindowText); Settings& s = Settings::getInstance(); - connect(&s, &Settings::compactLayoutChanged, - this, &GenericChatroomWidget::compactChange); + connect(&s, &Settings::compactLayoutChanged, this, &GenericChatroomWidget::compactChange); setAutoFillBackground(true); reloadTheme(); @@ -54,7 +54,7 @@ GenericChatroomWidget::GenericChatroomWidget(QWidget* parent) compactChange(isCompact()); } -bool GenericChatroomWidget::eventFilter(QObject *, QEvent *) +bool GenericChatroomWidget::eventFilter(QObject*, QEvent*) { return true; // Disable all events. } @@ -79,11 +79,10 @@ void GenericChatroomWidget::compactChange(bool _compact) setLayoutDirection(Qt::LeftToRight); // parent might have set Qt::RightToLeft // avatar - if (isCompact()) - { - delete textLayout; // Not needed + if (isCompact()) { + delete textLayout; // Not needed setFixedHeight(25); - avatar->setSize(QSize(20,20)); + avatar->setSize(QSize(20, 20)); mainLayout->addSpacing(18); mainLayout->addWidget(avatar); mainLayout->addSpacing(5); @@ -95,11 +94,9 @@ void GenericChatroomWidget::compactChange(bool _compact) mainLayout->activate(); statusMessageLabel->setFont(Style::getFont(Style::Small)); nameLabel->setFont(Style::getFont(Style::Medium)); - } - else - { + } else { setFixedHeight(55); - avatar->setSize(QSize(40,40)); + avatar->setSize(QSize(40, 40)); textLayout->addStretch(); textLayout->addWidget(nameLabel); textLayout->addWidget(statusMessageLabel); @@ -125,26 +122,23 @@ bool GenericChatroomWidget::isActive() void GenericChatroomWidget::setActive(bool _active) { active = _active; - if (active) - { + if (active) { setBackgroundRole(QPalette::Light); statusMessageLabel->setForegroundRole(QPalette::HighlightedText); nameLabel->setForegroundRole(QPalette::HighlightedText); - } - else - { + } else { setBackgroundRole(QPalette::Window); statusMessageLabel->setForegroundRole(QPalette::WindowText); nameLabel->setForegroundRole(QPalette::WindowText); } } -void GenericChatroomWidget::setName(const QString &name) +void GenericChatroomWidget::setName(const QString& name) { nameLabel->setText(name); } -void GenericChatroomWidget::setStatusMsg(const QString &status) +void GenericChatroomWidget::setStatusMsg(const QString& status) { statusMessageLabel->setText(status); } @@ -169,19 +163,19 @@ void GenericChatroomWidget::reloadTheme() QPalette p; p = statusMessageLabel->palette(); - p.setColor(QPalette::WindowText, Style::getColor(Style::LightGrey)); // Base color + p.setColor(QPalette::WindowText, Style::getColor(Style::LightGrey)); // Base color p.setColor(QPalette::HighlightedText, Style::getColor(Style::MediumGrey)); // Color when active statusMessageLabel->setPalette(p); p = nameLabel->palette(); - p.setColor(QPalette::WindowText, Style::getColor(Style::White)); // Base color + p.setColor(QPalette::WindowText, Style::getColor(Style::White)); // Base color p.setColor(QPalette::HighlightedText, Style::getColor(Style::DarkGrey)); // Color when active nameLabel->setPalette(p); p = palette(); - p.setColor(QPalette::Window, Style::getColor(Style::ThemeMedium)); // Base background color + p.setColor(QPalette::Window, Style::getColor(Style::ThemeMedium)); // Base background color p.setColor(QPalette::Highlight, Style::getColor(Style::ThemeLight)); // On mouse over - p.setColor(QPalette::Light, Style::getColor(Style::White)); // When active + p.setColor(QPalette::Light, Style::getColor(Style::White)); // When active setPalette(p); } diff --git a/src/widget/genericchatroomwidget.h b/src/widget/genericchatroomwidget.h index 46785ebbb..c04076672 100644 --- a/src/widget/genericchatroomwidget.h +++ b/src/widget/genericchatroomwidget.h @@ -43,10 +43,16 @@ public: virtual void setChatForm(ContentLayout* contentLayout) = 0; virtual void resetEventFlags() = 0; virtual QString getStatusString() const = 0; - virtual Friend* getFriend() const{return nullptr;} - virtual Group* getGroup() const{return nullptr;} + virtual Friend* getFriend() const + { + return nullptr; + } + virtual Group* getGroup() const + { + return nullptr; + } - virtual bool eventFilter(QObject *, QEvent *) final override; + virtual bool eventFilter(QObject*, QEvent*) final override; bool isActive(); void setActive(bool active); @@ -56,10 +62,10 @@ public: QString getStatusMsg() const; QString getTitle() const; - void reloadTheme(); + void reloadTheme(); public slots: - void compactChange(bool compact); + void compactChange(bool compact); signals: void chatroomWidgetClicked(GenericChatroomWidget* widget, bool group = false); @@ -77,7 +83,7 @@ protected: QVBoxLayout* textLayout = nullptr; MaskablePixmapWidget* avatar; CroppingLabel* statusMessageLabel; - bool active; + bool active; }; #endif // GENERICCHATROOMWIDGET_H diff --git a/src/widget/groupwidget.cpp b/src/widget/groupwidget.cpp index b2cf0a035..ffdd1681d 100644 --- a/src/widget/groupwidget.cpp +++ b/src/widget/groupwidget.cpp @@ -19,17 +19,17 @@ #include "groupwidget.h" -#include -#include -#include -#include -#include #include +#include #include +#include +#include +#include +#include #include "contentdialog.h" -#include "form/groupchatform.h" #include "maskablepixmapwidget.h" +#include "form/groupchatform.h" #include "src/core/core.h" #include "src/friend.h" #include "src/friendlist.h" @@ -53,10 +53,8 @@ GroupWidget::GroupWidget(int GroupId, QString Name) setAcceptDrops(true); - connect(nameLabel, &CroppingLabel::editFinished, [this](const QString &newName) - { - if (!newName.isEmpty()) - { + connect(nameLabel, &CroppingLabel::editFinished, [this](const QString& newName) { + if (!newName.isEmpty()) { Group* g = GroupList::findGroup(groupId); emit renameRequested(this, newName); emit g->getChatForm()->groupTitleChanged(groupId, newName.left(128)); @@ -103,31 +101,23 @@ void GroupWidget::contextMenuEvent(QContextMenuEvent* event) if (!active) setBackgroundRole(QPalette::Window); - if (selectedItem) - { - if (selectedItem == quitGroup) - { + if (selectedItem) { + if (selectedItem == quitGroup) { emit removeGroup(groupId); - } - else if (selectedItem == openChatWindow) - { + } else if (selectedItem == openChatWindow) { emit chatroomWidgetClicked(this, true); return; - } - else if (selectedItem == removeChatWindow) - { + } else if (selectedItem == removeChatWindow) { ContentDialog* contentDialog = ContentDialog::getGroupDialog(groupId); contentDialog->removeGroup(groupId); return; - } - else if (selectedItem == setTitle) - { + } else if (selectedItem == setTitle) { editName(); } } } -void GroupWidget::mousePressEvent(QMouseEvent *ev) +void GroupWidget::mousePressEvent(QMouseEvent* ev) { if (ev->button() == Qt::LeftButton) dragStartPos = ev->pos(); @@ -135,13 +125,12 @@ void GroupWidget::mousePressEvent(QMouseEvent *ev) GenericChatroomWidget::mousePressEvent(ev); } -void GroupWidget::mouseMoveEvent(QMouseEvent *ev) +void GroupWidget::mouseMoveEvent(QMouseEvent* ev) { if (!(ev->buttons() & Qt::LeftButton)) return; - if ((dragStartPos - ev->pos()).manhattanLength() > QApplication::startDragDistance()) - { + if ((dragStartPos - ev->pos()).manhattanLength() > QApplication::startDragDistance()) { QMimeData* mdata = new QMimeData; mdata->setText(getGroup()->getName()); @@ -155,8 +144,7 @@ void GroupWidget::mouseMoveEvent(QMouseEvent *ev) void GroupWidget::onUserListChanged() { Group* g = GroupList::findGroup(groupId); - if (g) - { + if (g) { int peersCount = g->getPeersCount(); if (peersCount == 1) statusMessageLabel->setText(tr("1 user in chat")); @@ -179,15 +167,12 @@ void GroupWidget::setAsInactiveChatroom() void GroupWidget::updateStatusLight() { - Group *g = GroupList::findGroup(groupId); + Group* g = GroupList::findGroup(groupId); - if (!g->getEventFlag()) - { + if (!g->getEventFlag()) { statusPic.setPixmap(QPixmap(":img/status/dot_online.svg")); statusPic.setMargin(3); - } - else - { + } else { statusPic.setPixmap(QPixmap(":img/status/dot_online_notification.svg")); statusPic.setMargin(0); } @@ -195,7 +180,7 @@ void GroupWidget::updateStatusLight() QString GroupWidget::getStatusString() const { - Group *g = GroupList::findGroup(groupId); + Group* g = GroupList::findGroup(groupId); if (!g->getEventFlag()) return "Online"; @@ -233,7 +218,7 @@ void GroupWidget::resetEventFlags() g->setMentionedFlag(false); } -void GroupWidget::dragEnterEvent(QDragEnterEvent *ev) +void GroupWidget::dragEnterEvent(QDragEnterEvent* ev) { ToxId toxId = ToxId(ev->mimeData()->text()); Friend* frnd = FriendList::findFriend(toxId.getPublicKey()); @@ -244,13 +229,13 @@ void GroupWidget::dragEnterEvent(QDragEnterEvent *ev) setBackgroundRole(QPalette::Highlight); } -void GroupWidget::dragLeaveEvent(QDragLeaveEvent *) +void GroupWidget::dragLeaveEvent(QDragLeaveEvent*) { if (!active) setBackgroundRole(QPalette::Window); } -void GroupWidget::dropEvent(QDropEvent *ev) +void GroupWidget::dropEvent(QDropEvent* ev) { ToxId toxId = ToxId(ev->mimeData()->text()); Friend* frnd = FriendList::findFriend(toxId.getPublicKey()); @@ -274,8 +259,7 @@ void GroupWidget::setName(const QString& name) void GroupWidget::retranslateUi() { Group* g = GroupList::findGroup(groupId); - if (g) - { + if (g) { int peersCount = g->getPeersCount(); if (peersCount == 1) statusMessageLabel->setText(tr("1 user in chat")); diff --git a/src/widget/groupwidget.h b/src/widget/groupwidget.h index 63c00aef1..ed947064e 100644 --- a/src/widget/groupwidget.h +++ b/src/widget/groupwidget.h @@ -46,7 +46,7 @@ signals: void removeGroup(int groupId); protected: - void contextMenuEvent(QContextMenuEvent * event) final override; + void contextMenuEvent(QContextMenuEvent* event) final override; void mousePressEvent(QMouseEvent* event) final override; void mouseMoveEvent(QMouseEvent* event) final override; void dragEnterEvent(QDragEnterEvent* ev) override; diff --git a/src/widget/gui.cpp b/src/widget/gui.cpp index 21274e827..fe966b1df 100644 --- a/src/widget/gui.cpp +++ b/src/widget/gui.cpp @@ -21,7 +21,6 @@ #include "gui.h" #include "widget.h" #include "src/nexus.h" -#include #include #include #include @@ -31,6 +30,7 @@ #include #include #include +#include /** * @class GUI @@ -43,8 +43,8 @@ * @brief Emitted when the GUI is resized on supported platforms. */ -GUI::GUI(QObject *parent) : - QObject(parent) +GUI::GUI(QObject* parent) + : QObject(parent) { assert(QThread::currentThread() == qApp->thread()); assert(Nexus::getDesktopGUI()); @@ -80,12 +80,9 @@ void GUI::clearContacts() */ void GUI::setEnabled(bool state) { - if (QThread::currentThread() == qApp->thread()) - { + if (QThread::currentThread() == qApp->thread()) { getInstance()._setEnabled(state); - } - else - { + } else { QMetaObject::invokeMethod(&getInstance(), "_setEnabled", Qt::BlockingQueuedConnection, Q_ARG(bool, state)); } @@ -99,12 +96,9 @@ void GUI::setEnabled(bool state) */ void GUI::setWindowTitle(const QString& title) { - if (QThread::currentThread() == qApp->thread()) - { + if (QThread::currentThread() == qApp->thread()) { getInstance()._setWindowTitle(title); - } - else - { + } else { QMetaObject::invokeMethod(&getInstance(), "_setWindowTitle", Qt::BlockingQueuedConnection, Q_ARG(const QString&, title)); } @@ -115,12 +109,9 @@ void GUI::setWindowTitle(const QString& title) */ void GUI::reloadTheme() { - if (QThread::currentThread() == qApp->thread()) - { + if (QThread::currentThread() == qApp->thread()) { getInstance()._reloadTheme(); - } - else - { + } else { QMetaObject::invokeMethod(&getInstance(), "_reloadTheme", Qt::BlockingQueuedConnection); } } @@ -130,13 +121,11 @@ void GUI::reloadTheme() */ void GUI::showUpdateDownloadProgress() { - if (QThread::currentThread() == qApp->thread()) - { + if (QThread::currentThread() == qApp->thread()) { getInstance()._showUpdateDownloadProgress(); - } - else - { - QMetaObject::invokeMethod(&getInstance(), "_showUpdateDownloadProgress", Qt::BlockingQueuedConnection); + } else { + QMetaObject::invokeMethod(&getInstance(), "_showUpdateDownloadProgress", + Qt::BlockingQueuedConnection); } } @@ -147,14 +136,11 @@ void GUI::showUpdateDownloadProgress() */ void GUI::showInfo(const QString& title, const QString& msg) { - if (QThread::currentThread() == qApp->thread()) - { + if (QThread::currentThread() == qApp->thread()) { getInstance()._showInfo(title, msg); - } - else - { + } else { QMetaObject::invokeMethod(&getInstance(), "_showInfo", Qt::BlockingQueuedConnection, - Q_ARG(const QString&, title), Q_ARG(const QString&, msg)); + Q_ARG(const QString&, title), Q_ARG(const QString&, msg)); } } @@ -165,14 +151,11 @@ void GUI::showInfo(const QString& title, const QString& msg) */ void GUI::showWarning(const QString& title, const QString& msg) { - if (QThread::currentThread() == qApp->thread()) - { + if (QThread::currentThread() == qApp->thread()) { getInstance()._showWarning(title, msg); - } - else - { + } else { QMetaObject::invokeMethod(&getInstance(), "_showWarning", Qt::BlockingQueuedConnection, - Q_ARG(const QString&, title), Q_ARG(const QString&, msg)); + Q_ARG(const QString&, title), Q_ARG(const QString&, msg)); } } @@ -183,19 +166,16 @@ void GUI::showWarning(const QString& title, const QString& msg) */ void GUI::showError(const QString& title, const QString& msg) { - if (QThread::currentThread() == qApp->thread()) - { + if (QThread::currentThread() == qApp->thread()) { // If the GUI hasn't started yet and we're on the main thread, // we still want to be able to show error messages if (!Nexus::getDesktopGUI()) QMessageBox::critical(nullptr, title, msg); else getInstance()._showError(title, msg); - } - else - { + } else { QMetaObject::invokeMethod(&getInstance(), "_showError", Qt::BlockingQueuedConnection, - Q_ARG(const QString&, title), Q_ARG(const QString&, msg)); + Q_ARG(const QString&, title), Q_ARG(const QString&, msg)); } } @@ -208,22 +188,16 @@ void GUI::showError(const QString& title, const QString& msg) * @param yesno Show "Yes" and "No" buttons. * @return True if the answer is positive, false otherwise. */ -bool GUI::askQuestion(const QString& title, const QString& msg, - bool defaultAns, bool warning, - bool yesno) +bool GUI::askQuestion(const QString& title, const QString& msg, bool defaultAns, bool warning, bool yesno) { - if (QThread::currentThread() == qApp->thread()) - { + if (QThread::currentThread() == qApp->thread()) { return getInstance()._askQuestion(title, msg, defaultAns, warning, yesno); - } - else - { + } else { bool ret; QMetaObject::invokeMethod(&getInstance(), "_askQuestion", Qt::BlockingQueuedConnection, - Q_RETURN_ARG(bool, ret), - Q_ARG(const QString&, title), Q_ARG(const QString&, msg), - Q_ARG(bool, defaultAns), Q_ARG(bool, warning), - Q_ARG(bool, yesno)); + Q_RETURN_ARG(bool, ret), Q_ARG(const QString&, title), + Q_ARG(const QString&, msg), Q_ARG(bool, defaultAns), + Q_ARG(bool, warning), Q_ARG(bool, yesno)); return ret; } } @@ -240,21 +214,17 @@ bool GUI::askQuestion(const QString& title, const QString& msg, * @param warning If is true, we will use a special warning style. * @return True if the answer is positive, false otherwise. */ -bool GUI::askQuestion(const QString& title, const QString& msg, - const QString& button1, const QString& button2, - bool defaultAns, bool warning) +bool GUI::askQuestion(const QString& title, const QString& msg, const QString& button1, + const QString& button2, bool defaultAns, bool warning) { - if (QThread::currentThread() == qApp->thread()) - { + if (QThread::currentThread() == qApp->thread()) { return getInstance()._askQuestion(title, msg, button1, button2, defaultAns, warning); - } - else - { + } else { bool ret; QMetaObject::invokeMethod(&getInstance(), "_askQuestion", Qt::BlockingQueuedConnection, - Q_RETURN_ARG(bool, ret), - Q_ARG(const QString&, title), Q_ARG(const QString&, msg), - Q_ARG(bool, defaultAns), Q_ARG(bool, warning)); + Q_RETURN_ARG(bool, ret), Q_ARG(const QString&, title), + Q_ARG(const QString&, msg), Q_ARG(bool, defaultAns), + Q_ARG(bool, warning)); return ret; } } @@ -268,30 +238,31 @@ bool GUI::askQuestion(const QString& title, const QString& msg, * @param label Is the text which is shown to the user (it should say what should be entered). * @param items Is the string list which is inserted into the combobox. * @param current Is the number of the item which should be the current item. - * @param editable If is true the user can enter their own text, otherwise the user may only select one of the existing items. - * @param ok If is nonnull will be set to true if the user pressed OK and to false if the user pressed Cancel. + * @param editable If is true the user can enter their own text, otherwise the user may only select + * one of the existing items. + * @param ok If is nonnull will be set to true if the user pressed OK and to false if the user + * pressed Cancel. * @param flags The dialog will uses to widget flags. - * @param hints Is the input method hints that will be used if the combobox is editable and an input method is active. - * @return This function returns the text of the current item, or if editable is true, the current text of the combobox. + * @param hints Is the input method hints that will be used if the combobox is editable and an input + * method is active. + * @return This function returns the text of the current item, or if editable is true, the current + * text of the combobox. */ -QString GUI::itemInputDialog(QWidget* parent, const QString& title, - const QString& label, const QStringList& items, - int current, bool editable, bool* ok, +QString GUI::itemInputDialog(QWidget* parent, const QString& title, const QString& label, + const QStringList& items, int current, bool editable, bool* ok, Qt::WindowFlags flags, Qt::InputMethodHints hints) { - if (QThread::currentThread() == qApp->thread()) - { - return getInstance()._itemInputDialog(parent, title, label, items, current, editable, ok, flags, hints); - } - else - { + if (QThread::currentThread() == qApp->thread()) { + return getInstance()._itemInputDialog(parent, title, label, items, current, editable, ok, + flags, hints); + } else { QString r; QMetaObject::invokeMethod(&getInstance(), "_itemInputDialog", Qt::BlockingQueuedConnection, - Q_RETURN_ARG(QString, r), - Q_ARG(QWidget*, parent), Q_ARG(const QString&, title), - Q_ARG(const QString&,label), Q_ARG(const QStringList&, items), - Q_ARG(int, current), Q_ARG(bool, editable), Q_ARG(bool*, ok), - Q_ARG(Qt::WindowFlags, flags), Q_ARG(Qt::InputMethodHints, hints)); + Q_RETURN_ARG(QString, r), Q_ARG(QWidget*, parent), + Q_ARG(const QString&, title), Q_ARG(const QString&, label), + Q_ARG(const QStringList&, items), Q_ARG(int, current), + Q_ARG(bool, editable), Q_ARG(bool*, ok), + Q_ARG(Qt::WindowFlags, flags), Q_ARG(Qt::InputMethodHints, hints)); return r; } } @@ -304,16 +275,13 @@ QString GUI::itemInputDialog(QWidget* parent, const QString& title, */ QString GUI::passwordDialog(const QString& cancel, const QString& body) { - if (QThread::currentThread() == qApp->thread()) - { + if (QThread::currentThread() == qApp->thread()) { return getInstance()._passwordDialog(cancel, body); - } - else - { + } else { QString r; QMetaObject::invokeMethod(&getInstance(), "_passwordDialog", Qt::BlockingQueuedConnection, - Q_RETURN_ARG(QString, r), - Q_ARG(const QString&, cancel), Q_ARG(const QString&, body)); + Q_RETURN_ARG(QString, r), Q_ARG(const QString&, cancel), + Q_ARG(const QString&, body)); return r; } } @@ -380,8 +348,7 @@ void GUI::_showUpdateDownloadProgress() w->showUpdateDownloadProgress(); } -bool GUI::_askQuestion(const QString& title, const QString& msg, - bool defaultAns, bool warning, +bool GUI::_askQuestion(const QString& title, const QString& msg, bool defaultAns, bool warning, bool yesno) { QString positiveButton = yesno ? QApplication::tr("Yes") : QApplication::tr("Ok"); @@ -390,9 +357,8 @@ bool GUI::_askQuestion(const QString& title, const QString& msg, return _askQuestion(title, msg, positiveButton, negativeButton, defaultAns, warning); } -bool GUI::_askQuestion(const QString& title, const QString& msg, - const QString& button1, const QString& button2, - bool defaultAns, bool warning) +bool GUI::_askQuestion(const QString& title, const QString& msg, const QString& button1, + const QString& button2, bool defaultAns, bool warning) { QMessageBox::Icon icon = warning ? QMessageBox::Warning : QMessageBox::Question; QMessageBox box(icon, title, msg, QMessageBox::NoButton, getMainWidget()); @@ -405,9 +371,8 @@ bool GUI::_askQuestion(const QString& title, const QString& msg, return box.clickedButton() == pushButton1; } -QString GUI::_itemInputDialog(QWidget* parent, const QString& title, - const QString& label, const QStringList& items, - int current, bool editable, bool* ok, +QString GUI::_itemInputDialog(QWidget* parent, const QString& title, const QString& label, + const QStringList& items, int current, bool editable, bool* ok, Qt::WindowFlags flags, Qt::InputMethodHints hints) { return QInputDialog::getItem(parent, title, label, items, current, editable, ok, flags, hints); @@ -432,26 +397,20 @@ QString GUI::_passwordDialog(const QString& cancel, const QString& body) // use another hack to reverse the default buttons. // http://www.qtcentre.org/threads/49924-Change-property-of-QInputDialog-button QList l = dialog.findChildren(); - if (!l.isEmpty()) - { - QPushButton* ok = l.first()->button(QDialogButtonBox::Ok); + if (!l.isEmpty()) { + QPushButton* ok = l.first()->button(QDialogButtonBox::Ok); QPushButton* cancel = l.first()->button(QDialogButtonBox::Cancel); - if (ok && cancel) - { + if (ok && cancel) { ok->setAutoDefault(false); ok->setDefault(false); ok->setText(QApplication::tr("Ok")); cancel->setAutoDefault(true); cancel->setDefault(true); cancel->setText(QApplication::tr("Cancel")); - } - else - { + } else { qWarning() << "PasswordDialog: Missing button!"; } - } - else - { + } else { qWarning() << "PasswordDialog: No QDialogButtonBox!"; } @@ -459,8 +418,7 @@ QString GUI::_passwordDialog(const QString& cancel, const QString& body) for (auto* label : dialog.findChildren()) label->setWordWrap(true); - while (true) - { + while (true) { int val = dialog.exec(); if (val == QDialog::Accepted) return QString(); diff --git a/src/widget/gui.h b/src/widget/gui.h index cb766ade5..da2f66aab 100644 --- a/src/widget/gui.h +++ b/src/widget/gui.h @@ -39,19 +39,16 @@ public: static void showInfo(const QString& title, const QString& msg); static void showWarning(const QString& title, const QString& msg); static void showError(const QString& title, const QString& msg); - static bool askQuestion(const QString& title, const QString& msg, - bool defaultAns = false, bool warning = true, - bool yesno = true); + static bool askQuestion(const QString& title, const QString& msg, bool defaultAns = false, + bool warning = true, bool yesno = true); - static bool askQuestion(const QString& title, const QString& msg, - const QString& button1, const QString& button2, - bool defaultAns = false, bool warning = true); + static bool askQuestion(const QString& title, const QString& msg, const QString& button1, + const QString& button2, bool defaultAns = false, bool warning = true); - static QString itemInputDialog(QWidget* parent, const QString& title, - const QString& label, const QStringList& items, - int current = 0, bool editable = true, bool* ok = 0, - Qt::WindowFlags flags = 0, - Qt::InputMethodHints hints = Qt::ImhNone); + static QString itemInputDialog(QWidget* parent, const QString& title, const QString& label, + const QStringList& items, int current = 0, bool editable = true, + bool* ok = 0, Qt::WindowFlags flags = 0, + Qt::InputMethodHints hints = Qt::ImhNone); static QString passwordDialog(const QString& cancel, const QString& body); @@ -59,7 +56,7 @@ signals: void resized(); private: - explicit GUI(QObject *parent = 0); + explicit GUI(QObject* parent = 0); private slots: // Private implementation, those must be called from the GUI thread @@ -71,17 +68,14 @@ private slots: void _showWarning(const QString& title, const QString& msg); void _showError(const QString& title, const QString& msg); void _showUpdateDownloadProgress(); - bool _askQuestion(const QString& title, const QString& msg, - bool defaultAns = false, bool warning = true, - bool yesno = true); - bool _askQuestion(const QString& title, const QString& msg, - const QString& button1, const QString& button2, - bool defaultAns = false, bool warning = true); - QString _itemInputDialog(QWidget* parent, const QString& title, - const QString& label, const QStringList& items, - int current = 0, bool editable = true, bool* ok = 0, - Qt::WindowFlags flags = 0, - Qt::InputMethodHints inputMethodHints = Qt::ImhNone); + bool _askQuestion(const QString& title, const QString& msg, bool defaultAns = false, + bool warning = true, bool yesno = true); + bool _askQuestion(const QString& title, const QString& msg, const QString& button1, + const QString& button2, bool defaultAns = false, bool warning = true); + QString _itemInputDialog(QWidget* parent, const QString& title, const QString& label, + const QStringList& items, int current = 0, bool editable = true, + bool* ok = 0, Qt::WindowFlags flags = 0, + Qt::InputMethodHints inputMethodHints = Qt::ImhNone); QString _passwordDialog(const QString& cancel, const QString& body); }; diff --git a/src/widget/loginscreen.cpp b/src/widget/loginscreen.cpp index 0ad34a07c..d6df9862e 100644 --- a/src/widget/loginscreen.cpp +++ b/src/widget/loginscreen.cpp @@ -20,22 +20,22 @@ #include "loginscreen.h" #include "ui_loginscreen.h" +#include "src/nexus.h" #include "src/persistence/profile.h" #include "src/persistence/profilelocker.h" -#include "src/nexus.h" #include "src/persistence/settings.h" #include "src/widget/form/setpassworddialog.h" -#include "src/widget/translator.h" #include "src/widget/style.h" #include "src/widget/tool/profileimporter.h" +#include "src/widget/translator.h" +#include #include #include -#include -LoginScreen::LoginScreen(QWidget* parent) : - QWidget(parent), - ui(new Ui::LoginScreen), - quitShortcut{QKeySequence(Qt::CTRL + Qt::Key_Q), this} +LoginScreen::LoginScreen(QWidget* parent) + : QWidget(parent) + , ui(new Ui::LoginScreen) + , quitShortcut{QKeySequence(Qt::CTRL + Qt::Key_Q), this} { ui->setupUi(this); @@ -51,12 +51,13 @@ LoginScreen::LoginScreen(QWidget* parent) : connect(ui->newPass, &QLineEdit::returnPressed, this, &LoginScreen::onCreateNewProfile); connect(ui->newPassConfirm, &QLineEdit::returnPressed, this, &LoginScreen::onCreateNewProfile); connect(ui->loginButton, &QPushButton::clicked, this, &LoginScreen::onLogin); - connect(ui->loginUsernames, &QComboBox::currentTextChanged, this, &LoginScreen::onLoginUsernameSelected); + connect(ui->loginUsernames, &QComboBox::currentTextChanged, this, + &LoginScreen::onLoginUsernameSelected); connect(ui->loginPassword, &QLineEdit::returnPressed, this, &LoginScreen::onLogin); connect(ui->newPass, &QLineEdit::textChanged, this, &LoginScreen::onPasswordEdited); connect(ui->newPassConfirm, &QLineEdit::textChanged, this, &LoginScreen::onPasswordEdited); connect(ui->autoLoginCB, &QCheckBox::stateChanged, this, &LoginScreen::onAutoLoginToggled); - connect(ui->importButton, &QPushButton::clicked, this, &LoginScreen::onImportProfile); + connect(ui->importButton, &QPushButton::clicked, this, &LoginScreen::onImportProfile); reset(); this->setStyleSheet(Style::getStylesheet(":/ui/loginScreen/loginScreen.css")); @@ -85,20 +86,16 @@ void LoginScreen::reset() Profile::scanProfiles(); QString lastUsed = Settings::getInstance().getCurrentProfile(); QVector profiles = Profile::getProfiles(); - for (QString profile : profiles) - { + for (QString profile : profiles) { ui->loginUsernames->addItem(profile); if (profile == lastUsed) - ui->loginUsernames->setCurrentIndex(ui->loginUsernames->count()-1); + ui->loginUsernames->setCurrentIndex(ui->loginUsernames->count() - 1); } - if (profiles.isEmpty()) - { + if (profiles.isEmpty()) { ui->stackedWidget->setCurrentIndex(0); ui->newUsername->setFocus(); - } - else - { + } else { ui->stackedWidget->setCurrentIndex(1); ui->loginPassword->setFocus(); } @@ -110,8 +107,7 @@ void LoginScreen::reset() bool LoginScreen::event(QEvent* event) { - switch (event->type()) - { + switch (event->type()) { #ifdef Q_OS_MAC case QEvent::WindowActivate: case QEvent::WindowStateChange: @@ -146,35 +142,37 @@ void LoginScreen::onCreateNewProfile() QString name = ui->newUsername->text(); QString pass = ui->newPass->text(); - if (name.isEmpty()) - { - QMessageBox::critical(this, tr("Couldn't create a new profile"), tr("The username must not be empty.")); + if (name.isEmpty()) { + QMessageBox::critical(this, tr("Couldn't create a new profile"), + tr("The username must not be empty.")); return; } - if (pass.size()!=0 && pass.size() < 6) - { - QMessageBox::critical(this, tr("Couldn't create a new profile"), tr("The password must be at least 6 characters long.")); + if (pass.size() != 0 && pass.size() < 6) { + QMessageBox::critical(this, tr("Couldn't create a new profile"), + tr("The password must be at least 6 characters long.")); return; } - if (ui->newPassConfirm->text() != pass) - { - QMessageBox::critical(this, tr("Couldn't create a new profile"), tr("The passwords you've entered are different.\nPlease make sure to enter same password twice.")); + if (ui->newPassConfirm->text() != pass) { + QMessageBox::critical(this, tr("Couldn't create a new profile"), + tr("The passwords you've entered are different.\nPlease make sure to " + "enter same password twice.")); return; } - if (Profile::exists(name)) - { - QMessageBox::critical(this, tr("Couldn't create a new profile"), tr("A profile with this name already exists.")); + if (Profile::exists(name)) { + QMessageBox::critical(this, tr("Couldn't create a new profile"), + tr("A profile with this name already exists.")); return; } Profile* profile = Profile::createProfile(name, pass); - if (!profile) - { + if (!profile) { // Unknown error - QMessageBox::critical(this, tr("Couldn't create a new profile"), tr("Unknown error: Couldn't create a new profile.\nIf you encountered this error, please report it.")); + QMessageBox::critical(this, tr("Couldn't create a new profile"), + tr("Unknown error: Couldn't create a new profile.\nIf you " + "encountered this error, please report it.")); return; } @@ -184,27 +182,25 @@ void LoginScreen::onCreateNewProfile() nexus.showMainGUI(); } -void LoginScreen::onLoginUsernameSelected(const QString &name) +void LoginScreen::onLoginUsernameSelected(const QString& name) { if (name.isEmpty()) return; ui->loginPassword->clear(); - if (Profile::isEncrypted(name)) - { + if (Profile::isEncrypted(name)) { ui->loginPasswordLabel->show(); ui->loginPassword->show(); // there is no way to do autologin if profile is encrypted, and // visible option confuses users into thinking that it is possible, // thus hide it ui->autoLoginCB->hide(); - } - else - { + } else { ui->loginPasswordLabel->hide(); ui->loginPassword->hide(); ui->autoLoginCB->show(); - ui->autoLoginCB->setToolTip(tr("Password protected profiles can't be automatically loaded.")); + ui->autoLoginCB->setToolTip( + tr("Password protected profiles can't be automatically loaded.")); } } @@ -214,34 +210,27 @@ void LoginScreen::onLogin() QString pass = ui->loginPassword->text(); // name can be empty when there are no profiles - if (name.isEmpty()) - { + if (name.isEmpty()) { QMessageBox::critical(this, tr("Couldn't load profile"), tr("There is no selected profile.\n\n" "You may want to create one.")); return; } - if (!ProfileLocker::isLockable(name)) - { + if (!ProfileLocker::isLockable(name)) { QMessageBox::critical(this, tr("Couldn't load this profile"), tr("This profile is already in use.")); return; } Profile* profile = Profile::loadProfile(name, pass); - if (!profile) - { - if (!ProfileLocker::isLockable(name)) - { + if (!profile) { + if (!ProfileLocker::isLockable(name)) { QMessageBox::critical(this, tr("Couldn't load this profile"), tr("Profile already in use. Close other clients.")); return; - } - else - { - QMessageBox::critical(this, tr("Couldn't load this profile"), - tr("Wrong password.")); + } else { + QMessageBox::critical(this, tr("Couldn't load this profile"), tr("Wrong password.")); ui->loginPassword->setFocus(); ui->loginPassword->selectAll(); return; @@ -277,7 +266,7 @@ void LoginScreen::retranslateUi() void LoginScreen::onImportProfile() { - ProfileImporter *pi = new ProfileImporter(this); + ProfileImporter* pi = new ProfileImporter(this); if (pi->importProfile()) reset(); diff --git a/src/widget/loginscreen.h b/src/widget/loginscreen.h index 82441842c..6e309c11b 100644 --- a/src/widget/loginscreen.h +++ b/src/widget/loginscreen.h @@ -21,9 +21,9 @@ #ifndef LOGINSCREEN_H #define LOGINSCREEN_H -#include #include #include +#include namespace Ui { class LoginScreen; @@ -45,7 +45,7 @@ signals: void closed(); protected: - virtual void closeEvent(QCloseEvent *event) final override; + virtual void closeEvent(QCloseEvent* event) final override; private slots: void onAutoLoginToggled(int state); @@ -66,7 +66,7 @@ private: void checkCapsLock(); private: - Ui::LoginScreen *ui; + Ui::LoginScreen* ui; QShortcut quitShortcut; }; diff --git a/src/widget/maskablepixmapwidget.cpp b/src/widget/maskablepixmapwidget.cpp index 6a45cf548..d4eb29446 100644 --- a/src/widget/maskablepixmapwidget.cpp +++ b/src/widget/maskablepixmapwidget.cpp @@ -49,12 +49,12 @@ void MaskablePixmapWidget::setClickable(bool clickable) unsetCursor(); } -void MaskablePixmapWidget::setPixmap(const QPixmap &pmap) +void MaskablePixmapWidget::setPixmap(const QPixmap& pmap) { - if (!pmap.isNull()) - { + if (!pmap.isNull()) { unscaled = pmap; - pixmap = pmap.scaled(width() - 2, height() - 2, Qt::KeepAspectRatioByExpanding, Qt::SmoothTransformation); + pixmap = pmap.scaled(width() - 2, height() - 2, Qt::KeepAspectRatioByExpanding, + Qt::SmoothTransformation); update(); } } @@ -74,28 +74,29 @@ void MaskablePixmapWidget::setSize(QSize size) if (!pmapMask.isNull()) mask = pmapMask.scaled(size, Qt::IgnoreAspectRatio, Qt::SmoothTransformation); - if (!unscaled.isNull()) - { - pixmap = unscaled.scaled(width() - 2, height() - 2, Qt::KeepAspectRatioByExpanding, Qt::SmoothTransformation); + if (!unscaled.isNull()) { + pixmap = unscaled.scaled(width() - 2, height() - 2, Qt::KeepAspectRatioByExpanding, + Qt::SmoothTransformation); update(); } } -void MaskablePixmapWidget::paintEvent(QPaintEvent *) +void MaskablePixmapWidget::paintEvent(QPaintEvent*) { renderTarget->fill(Qt::transparent); - QPoint offset((width() - pixmap.size().width())/2,(height() - pixmap.size().height())/2); // centering the pixmap + QPoint offset((width() - pixmap.size().width()) / 2, + (height() - pixmap.size().height()) / 2); // centering the pixmap QPainter painter(renderTarget); painter.setCompositionMode(QPainter::CompositionMode_SourceOver); - painter.drawPixmap(offset,pixmap); + painter.drawPixmap(offset, pixmap); painter.setCompositionMode(QPainter::CompositionMode_DestinationIn); - painter.drawPixmap(0,0,mask); + painter.drawPixmap(0, 0, mask); painter.end(); painter.begin(this); - painter.drawPixmap(0,0,*renderTarget); + painter.drawPixmap(0, 0, *renderTarget); } void MaskablePixmapWidget::mousePressEvent(QMouseEvent*) diff --git a/src/widget/maskablepixmapwidget.h b/src/widget/maskablepixmapwidget.h index e0e7d058f..1e5d2dea4 100644 --- a/src/widget/maskablepixmapwidget.h +++ b/src/widget/maskablepixmapwidget.h @@ -30,7 +30,7 @@ public: ~MaskablePixmapWidget(); void autopickBackground(); void setClickable(bool clickable); - void setPixmap(const QPixmap &pmap); + void setPixmap(const QPixmap& pmap); QPixmap getPixmap() const; void setSize(QSize size); @@ -38,8 +38,8 @@ signals: void clicked(); protected: - virtual void paintEvent(QPaintEvent *) final override; - virtual void mousePressEvent(QMouseEvent *) final override; + virtual void paintEvent(QPaintEvent*) final override; + virtual void mousePressEvent(QMouseEvent*) final override; private: QPixmap pixmap, mask, unscaled; diff --git a/src/widget/notificationedgewidget.cpp b/src/widget/notificationedgewidget.cpp index e0a272220..930297820 100644 --- a/src/widget/notificationedgewidget.cpp +++ b/src/widget/notificationedgewidget.cpp @@ -19,8 +19,8 @@ #include "notificationedgewidget.h" #include "style.h" -#include #include +#include #include @@ -54,7 +54,7 @@ void NotificationEdgeWidget::updateNotificationCount(int count) textLabel->setText(tr("Unread message(s)", "", count)); } -void NotificationEdgeWidget::mouseReleaseEvent(QMouseEvent *event) +void NotificationEdgeWidget::mouseReleaseEvent(QMouseEvent* event) { emit clicked(); QWidget::mousePressEvent(event); diff --git a/src/widget/notificationscrollarea.cpp b/src/widget/notificationscrollarea.cpp index 2be38a09a..8291cb4c5 100644 --- a/src/widget/notificationscrollarea.cpp +++ b/src/widget/notificationscrollarea.cpp @@ -17,16 +17,18 @@ along with qTox. If not, see . */ #include "notificationscrollarea.h" -#include "notificationedgewidget.h" #include "genericchatroomwidget.h" +#include "notificationedgewidget.h" #include #include NotificationScrollArea::NotificationScrollArea(QWidget* parent) : AdjustingScrollArea(parent) { - connect(verticalScrollBar(), &QAbstractSlider::valueChanged, this, &NotificationScrollArea::updateVisualTracking); - connect(verticalScrollBar(), &QAbstractSlider::rangeChanged, this, &NotificationScrollArea::updateVisualTracking); + connect(verticalScrollBar(), &QAbstractSlider::valueChanged, this, + &NotificationScrollArea::updateVisualTracking); + connect(verticalScrollBar(), &QAbstractSlider::rangeChanged, this, + &NotificationScrollArea::updateVisualTracking); } void NotificationScrollArea::trackWidget(GenericChatroomWidget* widget) @@ -35,27 +37,23 @@ void NotificationScrollArea::trackWidget(GenericChatroomWidget* widget) return; Visibility visibility = widgetVisible(widget); - if (visibility != Visible) - { - if (visibility == Above) - { - if (referencesAbove++ == 0) - { + if (visibility != Visible) { + if (visibility == Above) { + if (referencesAbove++ == 0) { assert(topEdge == nullptr); topEdge = new NotificationEdgeWidget(NotificationEdgeWidget::Top, this); - connect(topEdge, &NotificationEdgeWidget::clicked, this, &NotificationScrollArea::findPreviousWidget); + connect(topEdge, &NotificationEdgeWidget::clicked, this, + &NotificationScrollArea::findPreviousWidget); recalculateTopEdge(); topEdge->show(); } topEdge->updateNotificationCount(referencesAbove); - } - else - { - if (referencesBelow++ == 0) - { + } else { + if (referencesBelow++ == 0) { assert(bottomEdge == nullptr); bottomEdge = new NotificationEdgeWidget(NotificationEdgeWidget::Bottom, this); - connect(bottomEdge, &NotificationEdgeWidget::clicked, this, &NotificationScrollArea::findNextWidget); + connect(bottomEdge, &NotificationEdgeWidget::clicked, this, + &NotificationScrollArea::findNextWidget); recalculateBottomEdge(); bottomEdge->show(); } @@ -69,7 +67,8 @@ void NotificationScrollArea::trackWidget(GenericChatroomWidget* widget) /** * @brief Delete notification bar from visible elements on scroll area */ -void NotificationScrollArea::updateVisualTracking() { +void NotificationScrollArea::updateVisualTracking() +{ updateTracking(nullptr); } @@ -77,34 +76,23 @@ void NotificationScrollArea::updateVisualTracking() { * @brief Delete notification bar from visible elements and widget on scroll area * @param widget Chatroom widget to remove from tracked widgets */ -void NotificationScrollArea::updateTracking(GenericChatroomWidget *widget) +void NotificationScrollArea::updateTracking(GenericChatroomWidget* widget) { QHash::iterator i = trackedWidgets.begin(); - while (i != trackedWidgets.end()) - { - if (i.key() == widget || widgetVisible(i.key()) == Visible) - { - if (i.value() == Above) - { - if (--referencesAbove == 0) - { + while (i != trackedWidgets.end()) { + if (i.key() == widget || widgetVisible(i.key()) == Visible) { + if (i.value() == Above) { + if (--referencesAbove == 0) { topEdge->deleteLater(); topEdge = nullptr; - } - else - { + } else { topEdge->updateNotificationCount(referencesAbove); } - } - else - { - if (--referencesBelow == 0) - { + } else { + if (--referencesBelow == 0) { bottomEdge->deleteLater(); bottomEdge = nullptr; - } - else - { + } else { bottomEdge->updateNotificationCount(referencesBelow); } } @@ -115,7 +103,7 @@ void NotificationScrollArea::updateTracking(GenericChatroomWidget *widget) } } -void NotificationScrollArea::resizeEvent(QResizeEvent *event) +void NotificationScrollArea::resizeEvent(QResizeEvent* event) { if (topEdge != nullptr) recalculateTopEdge(); @@ -132,10 +120,8 @@ void NotificationScrollArea::findNextWidget() QHash::iterator i = trackedWidgets.begin(); // Find the first next, to avoid nullptr. - for (; i != trackedWidgets.end(); ++i) - { - if (i.value() == Below) - { + for (; i != trackedWidgets.end(); ++i) { + if (i.value() == Below) { next = i.key(); value = next->mapTo(viewport(), QPoint()).y(); break; @@ -143,13 +129,10 @@ void NotificationScrollArea::findNextWidget() } // Try finding a closer one. - for (; i != trackedWidgets.end(); ++i) - { - if (i.value() == Below) - { + for (; i != trackedWidgets.end(); ++i) { + if (i.value() == Below) { int y = i.key()->mapTo(viewport(), QPoint()).y(); - if (y < value) - { + if (y < value) { next = i.key(); value = y; } @@ -167,10 +150,8 @@ void NotificationScrollArea::findPreviousWidget() QHash::iterator i = trackedWidgets.begin(); // Find the first next, to avoid nullptr. - for (; i != trackedWidgets.end(); ++i) - { - if (i.value() == Above) - { + for (; i != trackedWidgets.end(); ++i) { + if (i.value() == Above) { next = i.key(); value = next->mapTo(viewport(), QPoint()).y(); break; @@ -178,13 +159,10 @@ void NotificationScrollArea::findPreviousWidget() } // Try finding a closer one. - for (; i != trackedWidgets.end(); ++i) - { - if (i.value() == Above) - { + for (; i != trackedWidgets.end(); ++i) { + if (i.value() == Above) { int y = i.key()->mapTo(viewport(), QPoint()).y(); - if (y > value) - { + if (y > value) { next = i.key(); value = y; } diff --git a/src/widget/notificationscrollarea.h b/src/widget/notificationscrollarea.h index 418f8bd4f..aa94bac41 100644 --- a/src/widget/notificationscrollarea.h +++ b/src/widget/notificationscrollarea.h @@ -34,10 +34,10 @@ public: public slots: void trackWidget(GenericChatroomWidget* widget); void updateVisualTracking(); - void updateTracking(GenericChatroomWidget *widget); + void updateTracking(GenericChatroomWidget* widget); protected: - void resizeEvent(QResizeEvent *event) final override; + void resizeEvent(QResizeEvent* event) final override; private slots: void findNextWidget(); diff --git a/src/widget/passwordedit.cpp b/src/widget/passwordedit.cpp index bbcc42b13..6cb606ad3 100644 --- a/src/widget/passwordedit.cpp +++ b/src/widget/passwordedit.cpp @@ -11,9 +11,9 @@ PasswordEdit::EventHandler* PasswordEdit::eventHandler{nullptr}; -PasswordEdit::PasswordEdit(QWidget* parent) : - QLineEdit(parent), - action(new QAction(this)) +PasswordEdit::PasswordEdit(QWidget* parent) + : QLineEdit(parent) + , action(new QAction(this)) { setEchoMode(QLineEdit::Password); @@ -44,11 +44,9 @@ void PasswordEdit::unregisterHandler() #ifdef ENABLE_CAPSLOCK_INDICATOR int idx; - if (eventHandler && (idx = eventHandler->actions.indexOf(action)) >= 0) - { + if (eventHandler && (idx = eventHandler->actions.indexOf(action)) >= 0) { eventHandler->actions.remove(idx); - if (eventHandler->actions.isEmpty()) - { + if (eventHandler->actions.isEmpty()) { delete eventHandler; eventHandler = nullptr; } @@ -88,10 +86,9 @@ void PasswordEdit::EventHandler::updateActions() action->setVisible(caps); } -bool PasswordEdit::EventHandler::eventFilter(QObject *obj, QEvent *event) +bool PasswordEdit::EventHandler::eventFilter(QObject* obj, QEvent* event) { - switch (event->type()) - { + switch (event->type()) { case QEvent::WindowActivate: case QEvent::KeyRelease: updateActions(); diff --git a/src/widget/passwordedit.h b/src/widget/passwordedit.h index 58513281d..1bf34b968 100644 --- a/src/widget/passwordedit.h +++ b/src/widget/passwordedit.h @@ -24,7 +24,7 @@ private: EventHandler(); ~EventHandler(); void updateActions(); - bool eventFilter(QObject *obj, QEvent *event); + bool eventFilter(QObject* obj, QEvent* event); }; void registerHandler(); diff --git a/src/widget/qrwidget.cpp b/src/widget/qrwidget.cpp index a7682adb7..41f3b567c 100644 --- a/src/widget/qrwidget.cpp +++ b/src/widget/qrwidget.cpp @@ -19,16 +19,16 @@ #include "qrwidget.h" -#include -#include #include +#include #include +#include #include #ifdef Q_OS_WIN32 - #include +#include #else - #include +#include #endif /** @@ -36,11 +36,13 @@ * @link https://stackoverflow.com/questions/21400254/how-to-draw-a-qr-code-with-qt-in-native-c-c */ -QRWidget::QRWidget(QWidget* parent) : QWidget(parent), data("0") -//Note: The encoding fails with empty string so I just default to something else. -//Use the setQRData() call to change this. +QRWidget::QRWidget(QWidget* parent) + : QWidget(parent) + , data("0") +// Note: The encoding fails with empty string so I just default to something else. +// Use the setQRData() call to change this. { - //size of the qimage might be problematic in the future, but it works for me + // size of the qimage might be problematic in the future, but it works for me size.setWidth(480); size.setHeight(480); image = new QImage(size, QImage::Format_RGB32); @@ -69,21 +71,23 @@ QImage* QRWidget::getImage() */ bool QRWidget::saveImage(QString path) { - return image->save(path, 0, 75); //0 - image format same as file extension, 75-quality, png file is ~6.3kb + return image + ->save(path, 0, + 75); // 0 - image format same as file extension, 75-quality, png file is ~6.3kb } -//http://stackoverflow.com/questions/21400254/how-to-draw-a-qr-code-with-qt-in-native-c-c +// http://stackoverflow.com/questions/21400254/how-to-draw-a-qr-code-with-qt-in-native-c-c void QRWidget::paintImage() { QPainter painter(image); - //NOTE: I have hardcoded some parameters here that would make more sense as variables. + // NOTE: I have hardcoded some parameters here that would make more sense as variables. // ECLEVEL_M is much faster recognizable by barcodescanner any any other type // https://fukuchi.org/works/qrencode/manual/qrencode_8h.html#a4cebc3c670efe1b8866b14c42737fc8f - // any mode other than QR_MODE_8 or QR_MODE_KANJI results in EINVAL. First 1 is version, second is case sensitivity + // any mode other than QR_MODE_8 or QR_MODE_KANJI results in EINVAL. First 1 is version, second + // is case sensitivity QRcode* qr = QRcode_encodeString(data.toStdString().c_str(), 1, QR_ECLEVEL_M, QR_MODE_8, 1); - if (qr != nullptr) - { + if (qr != nullptr) { QColor fg("black"); QColor bg("white"); painter.setBrush(bg); @@ -96,26 +100,20 @@ void QRWidget::paintImage() const double aspect = w / h; const double scale = ((aspect > 1.0) ? h : w) / s; - for (int y = 0; y < s; ++y) - { + for (int y = 0; y < s; ++y) { const int yy = y * s; - for (int x = 0; x < s; ++x) - { + for (int x = 0; x < s; ++x) { const int xx = yy + x; const unsigned char b = qr->data[xx]; - if (b & 0x01) - { - const double rx1 = x * scale, - ry1 = y * scale; + if (b & 0x01) { + const double rx1 = x * scale, ry1 = y * scale; QRectF r(rx1, ry1, scale, scale); painter.drawRects(&r, 1); } } } QRcode_free(qr); - } - else - { + } else { QColor error("red"); painter.setBrush(error); painter.drawRect(0, 0, width(), height()); diff --git a/src/widget/splitterrestorer.cpp b/src/widget/splitterrestorer.cpp index 35b044257..8d95ac8d8 100644 --- a/src/widget/splitterrestorer.cpp +++ b/src/widget/splitterrestorer.cpp @@ -54,9 +54,8 @@ SplitterRestorer::SplitterRestorer(QSplitter* splitter) */ void SplitterRestorer::restore(const QByteArray& state, const QSize& windowSize) { - bool brokenSplitter = !splitter->restoreState(state) || - splitter->orientation() != Qt::Horizontal || - splitter->handleWidth() > defaultWidth; + bool brokenSplitter = !splitter->restoreState(state) || splitter->orientation() != Qt::Horizontal + || splitter->handleWidth() > defaultWidth; if (splitter->count() == 2 && brokenSplitter) { splitter->setOrientation(Qt::Horizontal); diff --git a/src/widget/style.cpp b/src/widget/style.cpp index 01fc1f02d..0a45df581 100644 --- a/src/widget/style.cpp +++ b/src/widget/style.cpp @@ -21,15 +21,15 @@ #include "src/persistence/settings.h" #include "src/widget/gui.h" -#include #include -#include -#include -#include -#include +#include #include -#include +#include #include +#include +#include +#include +#include /** * @enum Style::Font @@ -67,47 +67,35 @@ QFont appFont(int pixelSize, int weight) QString qssifyFont(QFont font) { - return QString("%1 %2px \"%3\"") - .arg(font.weight()*8) - .arg(font.pixelSize()) - .arg(font.family()); + return QString("%1 %2px \"%3\"").arg(font.weight() * 8).arg(font.pixelSize()).arg(font.family()); } // colors as defined in // https://github.com/ItsDuke/Tox-UI/blob/master/UI%20GUIDELINES.md static QColor palette[] = { - QColor("#6bc260"), - QColor("#cebf44"), - QColor("#c84e4e"), - QColor("#000000"), - QColor("#1c1c1c"), - QColor("#414141"), - QColor("#414141").lighter(120), - QColor("#d1d1d1"), - QColor("#ffffff"), + QColor("#6bc260"), QColor("#cebf44"), QColor("#c84e4e"), QColor("#000000"), QColor("#1c1c1c"), + QColor("#414141"), QColor("#414141").lighter(120), QColor("#d1d1d1"), QColor("#ffffff"), QColor("#ff7700"), // Theme colors - QColor("#1c1c1c"), - QColor("#2a2a2a"), - QColor("#414141"), - QColor("#4e4e4e"), + QColor("#1c1c1c"), QColor("#2a2a2a"), QColor("#414141"), QColor("#4e4e4e"), }; static QMap dict; QStringList Style::getThemeColorNames() { - return {QObject::tr("Default"), QObject::tr("Blue"), QObject::tr("Olive"), QObject::tr("Red"), QObject::tr("Violet")}; + return {QObject::tr("Default"), QObject::tr("Blue"), QObject::tr("Olive"), QObject::tr("Red"), + QObject::tr("Violet")}; } -QList Style::themeColorColors = {QColor(), QColor("#004aa4"), QColor("#97ba00"), QColor("#c23716"), QColor("#4617b5")}; +QList Style::themeColorColors = {QColor(), QColor("#004aa4"), QColor("#97ba00"), + QColor("#c23716"), QColor("#4617b5")}; -QString Style::getStylesheet(const QString &filename, const QFont& baseFont) +QString Style::getStylesheet(const QString& filename, const QFont& baseFont) { QFile file(filename); - if (!file.open(QFile::ReadOnly | QFile::Text)) - { + if (!file.open(QFile::ReadOnly | QFile::Text)) { qWarning() << "Stylesheet " << filename << " not found"; return QString(); } @@ -128,13 +116,13 @@ QFont Style::getFont(Style::Font font) static int defSize = QFontInfo(QFont()).pixelSize(); static QFont fonts[] = { - appFont(defSize + 3, QFont::Bold), // extra big - appFont(defSize + 1, QFont::Normal), // big - appFont(defSize + 1, QFont::Bold), // big bold - appFont(defSize , QFont::Normal), // medium - appFont(defSize , QFont::Bold), // medium bold - appFont(defSize - 1, QFont::Normal), // small - appFont(defSize - 1, QFont::Light), // small light + appFont(defSize + 3, QFont::Bold), // extra big + appFont(defSize + 1, QFont::Normal), // big + appFont(defSize + 1, QFont::Bold), // big bold + appFont(defSize, QFont::Normal), // medium + appFont(defSize, QFont::Bold), // medium bold + appFont(defSize - 1, QFont::Normal), // small + appFont(defSize - 1, QFont::Light), // small light }; return fonts[font]; @@ -142,40 +130,36 @@ QFont Style::getFont(Style::Font font) QString Style::resolve(QString qss, const QFont& baseFont) { - if (dict.isEmpty()) - { - dict = { - // colors - {"@green", Style::getColor(Style::Green).name()}, - {"@yellow", Style::getColor(Style::Yellow).name()}, - {"@red", Style::getColor(Style::Red).name()}, - {"@black", Style::getColor(Style::Black).name()}, - {"@darkGrey", Style::getColor(Style::DarkGrey).name()}, - {"@mediumGrey", Style::getColor(Style::MediumGrey).name()}, - {"@mediumGreyLight", Style::getColor(Style::MediumGreyLight).name()}, - {"@lightGrey", Style::getColor(Style::LightGrey).name()}, - {"@white", Style::getColor(Style::White).name()}, - {"@orange", Style::getColor(Style::Orange).name()}, - {"@themeDark", Style::getColor(Style::ThemeDark).name()}, - {"@themeMediumDark", Style::getColor(Style::ThemeMediumDark).name()}, - {"@themeMedium", Style::getColor(Style::ThemeMedium).name()}, - {"@themeLight", Style::getColor(Style::ThemeLight).name()}, + if (dict.isEmpty()) { + dict = {// colors + {"@green", Style::getColor(Style::Green).name()}, + {"@yellow", Style::getColor(Style::Yellow).name()}, + {"@red", Style::getColor(Style::Red).name()}, + {"@black", Style::getColor(Style::Black).name()}, + {"@darkGrey", Style::getColor(Style::DarkGrey).name()}, + {"@mediumGrey", Style::getColor(Style::MediumGrey).name()}, + {"@mediumGreyLight", Style::getColor(Style::MediumGreyLight).name()}, + {"@lightGrey", Style::getColor(Style::LightGrey).name()}, + {"@white", Style::getColor(Style::White).name()}, + {"@orange", Style::getColor(Style::Orange).name()}, + {"@themeDark", Style::getColor(Style::ThemeDark).name()}, + {"@themeMediumDark", Style::getColor(Style::ThemeMediumDark).name()}, + {"@themeMedium", Style::getColor(Style::ThemeMedium).name()}, + {"@themeLight", Style::getColor(Style::ThemeLight).name()}, - // fonts - {"@baseFont", QString::fromUtf8("'%1' %2px") - .arg(baseFont.family()).arg(QFontInfo(baseFont).pixelSize())}, - {"@extraBig", qssifyFont(Style::getFont(Style::ExtraBig))}, - {"@big", qssifyFont(Style::getFont(Style::Big))}, - {"@bigBold", qssifyFont(Style::getFont(Style::BigBold))}, - {"@medium", qssifyFont(Style::getFont(Style::Medium))}, - {"@mediumBold", qssifyFont(Style::getFont(Style::MediumBold))}, - {"@small", qssifyFont(Style::getFont(Style::Small))}, - {"@smallLight", qssifyFont(Style::getFont(Style::SmallLight))} - }; + // fonts + {"@baseFont", + QString::fromUtf8("'%1' %2px").arg(baseFont.family()).arg(QFontInfo(baseFont).pixelSize())}, + {"@extraBig", qssifyFont(Style::getFont(Style::ExtraBig))}, + {"@big", qssifyFont(Style::getFont(Style::Big))}, + {"@bigBold", qssifyFont(Style::getFont(Style::BigBold))}, + {"@medium", qssifyFont(Style::getFont(Style::Medium))}, + {"@mediumBold", qssifyFont(Style::getFont(Style::MediumBold))}, + {"@small", qssifyFont(Style::getFont(Style::Small))}, + {"@smallLight", qssifyFont(Style::getFont(Style::SmallLight))}}; } - for (const QString& key : dict.keys()) - { + for (const QString& key : dict.keys()) { qss.replace(QRegularExpression(QString("%1\\b").arg(key)), dict[key]); } @@ -187,11 +171,9 @@ void Style::repolish(QWidget* w) w->style()->unpolish(w); w->style()->polish(w); - for (QObject* o : w->children()) - { + for (QObject* o : w->children()) { QWidget* c = qobject_cast(o); - if (c) - { + if (c) { c->style()->unpolish(c); c->style()->polish(c); } @@ -212,18 +194,15 @@ void Style::setThemeColor(int color) * * Pass an invalid QColor to reset to defaults. */ -void Style::setThemeColor(const QColor &color) +void Style::setThemeColor(const QColor& color) { - if (!color.isValid()) - { + if (!color.isValid()) { // Reset to default palette[ThemeDark] = QColor("#1c1c1c"); palette[ThemeMediumDark] = QColor("#2a2a2a"); palette[ThemeMedium] = QColor("#414141"); palette[ThemeLight] = QColor("#4e4e4e"); - } - else - { + } else { palette[ThemeDark] = color.darker(155); palette[ThemeMediumDark] = color.darker(135); palette[ThemeMedium] = color.darker(120); diff --git a/src/widget/style.h b/src/widget/style.h index 8d4f8237b..013a03423 100644 --- a/src/widget/style.h +++ b/src/widget/style.h @@ -65,7 +65,7 @@ public: static QString resolve(QString qss, const QFont& baseFont = QFont()); static void repolish(QWidget* w); static void setThemeColor(int color); - static void setThemeColor(const QColor &color); + static void setThemeColor(const QColor& color); static void applyTheme(); static QPixmap scaleSvgImage(const QString& path, uint32_t width, uint32_t height); diff --git a/src/widget/systemtrayicon.cpp b/src/widget/systemtrayicon.cpp index 63891b6c4..e7afdc08d 100644 --- a/src/widget/systemtrayicon.cpp +++ b/src/widget/systemtrayicon.cpp @@ -19,12 +19,12 @@ #include "systemtrayicon.h" +#include "src/persistence/settings.h" +#include +#include +#include #include #include -#include -#include -#include -#include "src/persistence/settings.h" SystemTrayIcon::SystemTrayIcon() { @@ -32,16 +32,15 @@ SystemTrayIcon::SystemTrayIcon() if (desktop.isEmpty()) desktop = getenv("DESKTOP_SESSION"); desktop = desktop.toLower(); - if (false); - #ifdef ENABLE_SYSTRAY_UNITY_BACKEND - else if (desktop == "unity") - { + if (false) + ; +#ifdef ENABLE_SYSTRAY_UNITY_BACKEND + else if (desktop == "unity") { qDebug() << "Using Unity backend"; gtk_init(nullptr, nullptr); QString settingsDir = Settings::getInstance().getSettingsDirPath(); - QFile iconFile(settingsDir+"/icon.png"); - if (iconFile.open(QIODevice::Truncate | QIODevice::WriteOnly)) - { + QFile iconFile(settingsDir + "/icon.png"); + if (iconFile.open(QIODevice::Truncate | QIODevice::WriteOnly)) { QFile resIconFile(":/img/icon.png"); if (resIconFile.open(QIODevice::ReadOnly)) iconFile.write(resIconFile.readAll()); @@ -50,18 +49,15 @@ SystemTrayIcon::SystemTrayIcon() } backendType = SystrayBackendType::Unity; unityMenu = gtk_menu_new(); - unityIndicator = app_indicator_new_with_path( - "qTox", - "icon", - APP_INDICATOR_CATEGORY_APPLICATION_STATUS, - settingsDir.toStdString().c_str() - ); + unityIndicator = + app_indicator_new_with_path("qTox", "icon", APP_INDICATOR_CATEGORY_APPLICATION_STATUS, + settingsDir.toStdString().c_str()); app_indicator_set_menu(unityIndicator, GTK_MENU(unityMenu)); } - #endif - #ifdef ENABLE_SYSTRAY_GTK_BACKEND - else if (desktop == "xfce" || desktop.contains("gnome") || desktop == "mate" || desktop == "x-cinnamon") - { +#endif +#ifdef ENABLE_SYSTRAY_GTK_BACKEND + else if (desktop == "xfce" || desktop.contains("gnome") || desktop == "mate" + || desktop == "x-cinnamon") { qDebug() << "Using GTK backend"; backendType = SystrayBackendType::GTK; gtk_init(nullptr, nullptr); @@ -70,23 +66,19 @@ SystemTrayIcon::SystemTrayIcon() gtkMenu = gtk_menu_new(); - void (*callbackTrigger)(GtkStatusIcon*, gpointer) = - [](GtkStatusIcon*, gpointer data) - { + void (*callbackTrigger)(GtkStatusIcon*, gpointer) = [](GtkStatusIcon*, gpointer data) { static_cast(data)->activated(QSystemTrayIcon::Trigger); }; g_signal_connect(gtkIcon, "activate", G_CALLBACK(callbackTrigger), this); - void (*callbackButtonClick)(GtkStatusIcon*, GdkEvent*, gpointer) = - [](GtkStatusIcon*, GdkEvent* event, gpointer data) - { + void (*callbackButtonClick)(GtkStatusIcon*, GdkEvent*, + gpointer) = [](GtkStatusIcon*, GdkEvent* event, gpointer data) { if (event->button.button == 2) static_cast(data)->activated(QSystemTrayIcon::MiddleClick); }; g_signal_connect(gtkIcon, "button-release-event", G_CALLBACK(callbackButtonClick), this); } - #endif - else - { +#endif + else { qDebug() << "Using the Qt backend"; qtIcon = new QSystemTrayIcon; backendType = SystrayBackendType::Qt; @@ -103,22 +95,20 @@ SystemTrayIcon::~SystemTrayIcon() QString SystemTrayIcon::extractIconToFile(QIcon icon, QString name) { QString iconPath; - (void) icon; - (void) name; + (void)icon; + (void)name; #ifdef ENABLE_SYSTRAY_UNITY_BACKEND - iconPath = Settings::getInstance().getSettingsDirPath()+"/"+name+".png"; - QSize iconSize = icon.actualSize(QSize{64,64}); + iconPath = Settings::getInstance().getSettingsDirPath() + "/" + name + ".png"; + QSize iconSize = icon.actualSize(QSize{64, 64}); icon.pixmap(iconSize).save(iconPath); #endif return iconPath; } #if defined(ENABLE_SYSTRAY_GTK_BACKEND) || defined(ENABLE_SYSTRAY_STATUSNOTIFIER_BACKEND) -GdkPixbuf* SystemTrayIcon::convertQIconToPixbuf(const QIcon &icon) +GdkPixbuf* SystemTrayIcon::convertQIconToPixbuf(const QIcon& icon) { - void (*callbackFreeImage)(guchar*, gpointer) = - [](guchar* image_bytes, gpointer) - { + void (*callbackFreeImage)(guchar*, gpointer) = [](guchar* image_bytes, gpointer) { delete[] image_bytes; }; QImage image = icon.pixmap(64, 64).toImage(); @@ -127,142 +117,127 @@ GdkPixbuf* SystemTrayIcon::convertQIconToPixbuf(const QIcon &icon) guchar* image_bytes = new guchar[image.byteCount()]; memcpy(image_bytes, image.bits(), image.byteCount()); - return gdk_pixbuf_new_from_data(image_bytes, GDK_COLORSPACE_RGB, image.hasAlphaChannel(), - 8, image.width(), image.height(), image.bytesPerLine(), + return gdk_pixbuf_new_from_data(image_bytes, GDK_COLORSPACE_RGB, image.hasAlphaChannel(), 8, + image.width(), image.height(), image.bytesPerLine(), callbackFreeImage, NULL); } #endif void SystemTrayIcon::setContextMenu(QMenu* menu) { - if (false); - #ifdef ENABLE_SYSTRAY_STATUSNOTIFIER_BACKEND - else if (backendType == SystrayBackendType::StatusNotifier) - { - void (*callbackClick)(StatusNotifier*, gint, gint, gpointer) = - [](StatusNotifier*, gint, gint, gpointer data) - { + if (false) + ; +#ifdef ENABLE_SYSTRAY_STATUSNOTIFIER_BACKEND + else if (backendType == SystrayBackendType::StatusNotifier) { + void (*callbackClick)(StatusNotifier*, gint, gint, gpointer) = [](StatusNotifier*, gint, + gint, gpointer data) { static_cast(data)->activated(QSystemTrayIcon::Trigger); }; g_signal_connect(statusNotifier, "activate", G_CALLBACK(callbackClick), this); - void (*callbackMiddleClick)(StatusNotifier*, gint, gint, gpointer) = - [](StatusNotifier*, gint, gint, gpointer data) - { + void (*callbackMiddleClick)(StatusNotifier*, gint, gint, + gpointer) = [](StatusNotifier*, gint, gint, gpointer data) { static_cast(data)->activated(QSystemTrayIcon::MiddleClick); }; g_signal_connect(statusNotifier, "secondary_activate", G_CALLBACK(callbackMiddleClick), this); - for (QAction* a : menu->actions()) - { - QString aText = a->text().replace('&',""); + for (QAction* a : menu->actions()) { + QString aText = a->text().replace('&', ""); GtkWidget* item; if (a->isSeparator()) item = gtk_menu_item_new(); else if (a->icon().isNull()) item = gtk_menu_item_new_with_label(aText.toStdString().c_str()); - else - { + else { GdkPixbuf* pixbuf = convertQIconToPixbuf(a->icon()); item = gtk_image_menu_item_new_with_label(aText.toStdString().c_str()); - gtk_image_menu_item_set_image(GTK_IMAGE_MENU_ITEM(item), gtk_image_new_from_pixbuf(pixbuf)); - gtk_image_menu_item_set_always_show_image(GTK_IMAGE_MENU_ITEM(item),TRUE); + gtk_image_menu_item_set_image(GTK_IMAGE_MENU_ITEM(item), + gtk_image_new_from_pixbuf(pixbuf)); + gtk_image_menu_item_set_always_show_image(GTK_IMAGE_MENU_ITEM(item), TRUE); g_object_unref(pixbuf); } gtk_menu_shell_append(GTK_MENU_SHELL(snMenu), item); - void (*callback)(GtkMenu*, gpointer data) = [](GtkMenu*, gpointer a) - { + void (*callback)(GtkMenu*, gpointer data) = [](GtkMenu*, gpointer a) { ((QAction*)a)->activate(QAction::Trigger); }; g_signal_connect(item, "activate", G_CALLBACK(callback), a); gtk_widget_show(item); } - void (*callbackMenu)(StatusNotifier*, gint, gint, gpointer) = - [](StatusNotifier*, gint, gint, gpointer data) - { + void (*callbackMenu)(StatusNotifier*, gint, gint, gpointer) = [](StatusNotifier*, gint, + gint, gpointer data) { gtk_widget_show_all(static_cast(data)->snMenu); - gtk_menu_popup(GTK_MENU(static_cast(data)->snMenu), 0, 0, 0, 0, 3, gtk_get_current_event_time()); + gtk_menu_popup(GTK_MENU(static_cast(data)->snMenu), 0, 0, 0, 0, 3, + gtk_get_current_event_time()); }; g_signal_connect(statusNotifier, "context-menu", G_CALLBACK(callbackMenu), this); } - #endif - #ifdef ENABLE_SYSTRAY_GTK_BACKEND - else if (backendType == SystrayBackendType::GTK) - { - for (QAction* a : menu->actions()) - { - QString aText = a->text().replace('&',""); +#endif +#ifdef ENABLE_SYSTRAY_GTK_BACKEND + else if (backendType == SystrayBackendType::GTK) { + for (QAction* a : menu->actions()) { + QString aText = a->text().replace('&', ""); GtkWidget* item; if (a->isSeparator()) item = gtk_menu_item_new(); else if (a->icon().isNull()) item = gtk_menu_item_new_with_label(aText.toStdString().c_str()); - else - { + else { GdkPixbuf* pixbuf = convertQIconToPixbuf(a->icon()); item = gtk_image_menu_item_new_with_label(aText.toStdString().c_str()); - gtk_image_menu_item_set_image(GTK_IMAGE_MENU_ITEM(item), gtk_image_new_from_pixbuf(pixbuf)); - gtk_image_menu_item_set_always_show_image(GTK_IMAGE_MENU_ITEM(item),TRUE); + gtk_image_menu_item_set_image(GTK_IMAGE_MENU_ITEM(item), + gtk_image_new_from_pixbuf(pixbuf)); + gtk_image_menu_item_set_always_show_image(GTK_IMAGE_MENU_ITEM(item), TRUE); g_object_unref(pixbuf); } gtk_menu_shell_append(GTK_MENU_SHELL(gtkMenu), item); - void (*callback)(GtkMenu*, gpointer data) = [](GtkMenu*, gpointer a) - { + void (*callback)(GtkMenu*, gpointer data) = [](GtkMenu*, gpointer a) { ((QAction*)a)->activate(QAction::Trigger); }; g_signal_connect(item, "activate", G_CALLBACK(callback), a); gtk_widget_show(item); } - void (*callbackMenu)(GtkMenu*, gint, gint, gpointer) = - [](GtkMenu*, gint, gint, gpointer data) - { + void (*callbackMenu)(GtkMenu*, gint, gint, gpointer) = [](GtkMenu*, gint, gint, gpointer data) { gtk_widget_show_all(static_cast(data)->gtkMenu); - gtk_menu_popup(GTK_MENU(static_cast(data)->gtkMenu), 0, 0, 0, 0, 3, gtk_get_current_event_time()); + gtk_menu_popup(GTK_MENU(static_cast(data)->gtkMenu), 0, 0, 0, 0, 3, + gtk_get_current_event_time()); }; g_signal_connect(gtkIcon, "popup-menu", G_CALLBACK(callbackMenu), this); } - #endif - #ifdef ENABLE_SYSTRAY_UNITY_BACKEND - else if (backendType == SystrayBackendType::Unity) - { - for (QAction* a : menu->actions()) - { - QString aText = a->text().replace('&',""); +#endif +#ifdef ENABLE_SYSTRAY_UNITY_BACKEND + else if (backendType == SystrayBackendType::Unity) { + for (QAction* a : menu->actions()) { + QString aText = a->text().replace('&', ""); GtkWidget* item; if (a->isSeparator()) item = gtk_menu_item_new(); else if (a->icon().isNull()) item = gtk_menu_item_new_with_label(aText.toStdString().c_str()); - else - { - QString iconPath = extractIconToFile(a->icon(),"iconmenu"+a->icon().name()); + else { + QString iconPath = extractIconToFile(a->icon(), "iconmenu" + a->icon().name()); GtkWidget* image = gtk_image_new_from_file(iconPath.toStdString().c_str()); item = gtk_image_menu_item_new_with_label(aText.toStdString().c_str()); gtk_image_menu_item_set_image(GTK_IMAGE_MENU_ITEM(item), image); - gtk_image_menu_item_set_always_show_image(GTK_IMAGE_MENU_ITEM(item),TRUE); + gtk_image_menu_item_set_always_show_image(GTK_IMAGE_MENU_ITEM(item), TRUE); } gtk_menu_shell_append(GTK_MENU_SHELL(unityMenu), item); - void (*callback)(GtkMenu*, gpointer data) = [](GtkMenu*, gpointer a) - { + void (*callback)(GtkMenu*, gpointer data) = [](GtkMenu*, gpointer a) { static_cast(a)->activate(QAction::Trigger); }; g_signal_connect(item, "activate", G_CALLBACK(callback), a); gtk_widget_show(item); } app_indicator_set_menu(unityIndicator, GTK_MENU(unityMenu)); - DbusmenuServer *menuServer; - DbusmenuMenuitem *rootMenuItem; + DbusmenuServer* menuServer; + DbusmenuMenuitem* rootMenuItem; g_object_get(unityIndicator, "dbus-menu-server", &menuServer, NULL); g_object_get(menuServer, "root-node", &rootMenuItem, NULL); - void (*callback)(DbusmenuMenuitem *, gpointer) = - [](DbusmenuMenuitem *, gpointer data) - { + void (*callback)(DbusmenuMenuitem*, gpointer) = [](DbusmenuMenuitem*, gpointer data) { static_cast(data)->activated(QSystemTrayIcon::Unknown); }; g_signal_connect(rootMenuItem, "about-to-show", G_CALLBACK(callback), this); } - #endif - else if (backendType == SystrayBackendType::Qt) - { +#endif + else if (backendType == SystrayBackendType::Qt) { qtIcon->setContextMenu(menu); } } @@ -279,36 +254,33 @@ void SystemTrayIcon::hide() void SystemTrayIcon::setVisible(bool newState) { - if (false); - #ifdef ENABLE_SYSTRAY_STATUSNOTIFIER_BACKEND - else if (backendType == SystrayBackendType::StatusNotifier) - { + if (false) + ; +#ifdef ENABLE_SYSTRAY_STATUSNOTIFIER_BACKEND + else if (backendType == SystrayBackendType::StatusNotifier) { if (newState) status_notifier_set_status(statusNotifier, STATUS_NOTIFIER_STATUS_ACTIVE); else status_notifier_set_status(statusNotifier, STATUS_NOTIFIER_STATUS_PASSIVE); } - #endif - #ifdef ENABLE_SYSTRAY_GTK_BACKEND - else if (backendType == SystrayBackendType::GTK) - { +#endif +#ifdef ENABLE_SYSTRAY_GTK_BACKEND + else if (backendType == SystrayBackendType::GTK) { if (newState) gtk_status_icon_set_visible(gtkIcon, true); else gtk_status_icon_set_visible(gtkIcon, false); } - #endif - #ifdef ENABLE_SYSTRAY_UNITY_BACKEND - else if (backendType == SystrayBackendType::Unity) - { +#endif +#ifdef ENABLE_SYSTRAY_UNITY_BACKEND + else if (backendType == SystrayBackendType::Unity) { if (newState) app_indicator_set_status(unityIndicator, APP_INDICATOR_STATUS_ACTIVE); else app_indicator_set_status(unityIndicator, APP_INDICATOR_STATUS_PASSIVE); } - #endif - else if (backendType == SystrayBackendType::Qt) - { +#endif + else if (backendType == SystrayBackendType::Qt) { if (newState) qtIcon->show(); else @@ -316,43 +288,37 @@ void SystemTrayIcon::setVisible(bool newState) } } -void SystemTrayIcon::setIcon(QIcon &icon) +void SystemTrayIcon::setIcon(QIcon& icon) { - if (false); - #ifdef ENABLE_SYSTRAY_STATUSNOTIFIER_BACKEND - else if (backendType == SystrayBackendType::StatusNotifier) - { + if (false) + ; +#ifdef ENABLE_SYSTRAY_STATUSNOTIFIER_BACKEND + else if (backendType == SystrayBackendType::StatusNotifier) { GdkPixbuf* pixbuf = convertQIconToPixbuf(icon); status_notifier_set_from_pixbuf(statusNotifier, STATUS_NOTIFIER_ICON, pixbuf); g_object_unref(pixbuf); } - #endif - #ifdef ENABLE_SYSTRAY_GTK_BACKEND - else if (backendType == SystrayBackendType::GTK) - { +#endif +#ifdef ENABLE_SYSTRAY_GTK_BACKEND + else if (backendType == SystrayBackendType::GTK) { GdkPixbuf* pixbuf = convertQIconToPixbuf(icon); gtk_status_icon_set_from_pixbuf(gtkIcon, pixbuf); g_object_unref(pixbuf); } - #endif - #ifdef ENABLE_SYSTRAY_UNITY_BACKEND - else if (backendType == SystrayBackendType::Unity) - { +#endif +#ifdef ENABLE_SYSTRAY_UNITY_BACKEND + else if (backendType == SystrayBackendType::Unity) { // Alternate file names or appindicator will not reload the icon - if (app_indicator_get_icon(unityIndicator) == QString("icon2")) - { - extractIconToFile(icon,"icon"); - app_indicator_set_icon_full(unityIndicator, "icon","qtox"); - } - else - { - extractIconToFile(icon,"icon2"); - app_indicator_set_icon_full(unityIndicator, "icon2","qtox"); + if (app_indicator_get_icon(unityIndicator) == QString("icon2")) { + extractIconToFile(icon, "icon"); + app_indicator_set_icon_full(unityIndicator, "icon", "qtox"); + } else { + extractIconToFile(icon, "icon2"); + app_indicator_set_icon_full(unityIndicator, "icon2", "qtox"); } } - #endif - else if (backendType == SystrayBackendType::Qt) - { +#endif + else if (backendType == SystrayBackendType::Qt) { qtIcon->setIcon(icon); } } diff --git a/src/widget/systemtrayicon.h b/src/widget/systemtrayicon.h index 186337ea6..da3fc97e1 100644 --- a/src/widget/systemtrayicon.h +++ b/src/widget/systemtrayicon.h @@ -37,16 +37,16 @@ public: void show(); void hide(); void setVisible(bool); - void setIcon(QIcon &icon); + void setIcon(QIcon& icon); SystrayBackendType backend() const; signals: void activated(QSystemTrayIcon::ActivationReason); private: - QString extractIconToFile(QIcon icon, QString name="icon"); + QString extractIconToFile(QIcon icon, QString name = "icon"); #if defined(ENABLE_SYSTRAY_GTK_BACKEND) || defined(ENABLE_SYSTRAY_STATUSNOTIFIER_BACKEND) - static GdkPixbuf* convertQIconToPixbuf(const QIcon &icon); + static GdkPixbuf* convertQIconToPixbuf(const QIcon& icon); #endif private: @@ -54,8 +54,8 @@ private: QSystemTrayIcon* qtIcon = nullptr; #ifdef ENABLE_SYSTRAY_UNITY_BACKEND - AppIndicator *unityIndicator; - GtkWidget *unityMenu; + AppIndicator* unityIndicator; + GtkWidget* unityMenu; #endif #ifdef ENABLE_SYSTRAY_STATUSNOTIFIER_BACKEND StatusNotifier* statusNotifier; diff --git a/src/widget/systemtrayicon_private.h b/src/widget/systemtrayicon_private.h index 296f8bf3e..cfbb451c9 100644 --- a/src/widget/systemtrayicon_private.h +++ b/src/widget/systemtrayicon_private.h @@ -28,12 +28,12 @@ #undef signals #endif extern "C" { - #include - #include - #include - #include - #include - #include "src/platform/statusnotifier/statusnotifier.h" +#include "src/platform/statusnotifier/statusnotifier.h" +#include +#include +#include +#include +#include } #define signals public #endif @@ -43,9 +43,9 @@ extern "C" { #undef signals #endif extern "C" { - #include - #include - #include +#include +#include +#include } #define signals public #endif @@ -55,7 +55,7 @@ extern "C" { #undef signals #endif extern "C" { - #include +#include } #define signals public #endif diff --git a/src/widget/tool/activatedialog.cpp b/src/widget/tool/activatedialog.cpp index b89977817..c9ae9dc2b 100644 --- a/src/widget/tool/activatedialog.cpp +++ b/src/widget/tool/activatedialog.cpp @@ -24,7 +24,6 @@ ActivateDialog::ActivateDialog(QWidget* parent, Qt::WindowFlags f) : QDialog(parent, f) { - } bool ActivateDialog::event(QEvent* event) diff --git a/src/widget/tool/adjustingscrollarea.cpp b/src/widget/tool/adjustingscrollarea.cpp index e3151d21a..c529d8797 100644 --- a/src/widget/tool/adjustingscrollarea.cpp +++ b/src/widget/tool/adjustingscrollarea.cpp @@ -19,20 +19,20 @@ #include "adjustingscrollarea.h" +#include #include #include #include -#include AdjustingScrollArea::AdjustingScrollArea(QWidget* parent) : QScrollArea(parent) { - } -void AdjustingScrollArea::resizeEvent(QResizeEvent *ev) +void AdjustingScrollArea::resizeEvent(QResizeEvent* ev) { - int scrollBarWidth = verticalScrollBar()->isVisible() ? verticalScrollBar()->sizeHint().width() : 0; + int scrollBarWidth = + verticalScrollBar()->isVisible() ? verticalScrollBar()->sizeHint().width() : 0; if (layoutDirection() == Qt::RightToLeft) setViewportMargins(-scrollBarWidth, 0, 0, 0); @@ -43,8 +43,7 @@ void AdjustingScrollArea::resizeEvent(QResizeEvent *ev) QSize AdjustingScrollArea::sizeHint() const { - if (widget()) - { + if (widget()) { int scrollbarWidth = verticalScrollBar()->isVisible() ? verticalScrollBar()->width() : 0; return widget()->sizeHint() + QSize(scrollbarWidth, 0); } diff --git a/src/widget/tool/adjustingscrollarea.h b/src/widget/tool/adjustingscrollarea.h index 8a1c3eb88..b55fba4aa 100644 --- a/src/widget/tool/adjustingscrollarea.h +++ b/src/widget/tool/adjustingscrollarea.h @@ -30,7 +30,7 @@ public: virtual ~AdjustingScrollArea() = default; protected: - virtual void resizeEvent(QResizeEvent *ev) override; + virtual void resizeEvent(QResizeEvent* ev) override; virtual QSize sizeHint() const final override; }; diff --git a/src/widget/tool/callconfirmwidget.cpp b/src/widget/tool/callconfirmwidget.cpp index d3c6777be..a64ed11c6 100644 --- a/src/widget/tool/callconfirmwidget.cpp +++ b/src/widget/tool/callconfirmwidget.cpp @@ -20,16 +20,16 @@ #include "callconfirmwidget.h" #include "src/widget/widget.h" -#include -#include +#include #include #include -#include -#include -#include #include -#include +#include #include +#include +#include +#include +#include /** * @class CallConfirmWidget @@ -51,12 +51,16 @@ * @brief Used to correct the rounding factors on non-square rects */ -CallConfirmWidget::CallConfirmWidget(const QWidget* Anchor, const Friend& f) : - QWidget(), anchor(Anchor), f(f), - rectW{120}, rectH{85}, - spikeW{30}, spikeH{15}, - roundedFactor{20}, - rectRatio(static_cast(rectH)/static_cast(rectW)) +CallConfirmWidget::CallConfirmWidget(const QWidget* Anchor, const Friend& f) + : QWidget() + , anchor(Anchor) + , f(f) + , rectW{120} + , rectH{85} + , spikeW{30} + , spikeH{15} + , roundedFactor{20} + , rectRatio(static_cast(rectH) / static_cast(rectW)) { setWindowFlags(Qt::SubWindow); setAttribute(Qt::WA_DeleteOnClose); @@ -65,12 +69,12 @@ CallConfirmWidget::CallConfirmWidget(const QWidget* Anchor, const Friend& f) : palette.setColor(QPalette::WindowText, Qt::white); setPalette(palette); - QVBoxLayout *layout = new QVBoxLayout(this); - QLabel *callLabel = new QLabel(QObject::tr("Incoming call..."), this); + QVBoxLayout* layout = new QVBoxLayout(this); + QLabel* callLabel = new QLabel(QObject::tr("Incoming call..."), this); callLabel->setStyleSheet("color: white"); callLabel->setWordWrap(true); callLabel->setAlignment(Qt::AlignHCenter); - QDialogButtonBox *buttonBox = new QDialogButtonBox(Qt::Horizontal, this); + QDialogButtonBox* buttonBox = new QDialogButtonBox(Qt::Horizontal, this); QPushButton *accept = new QPushButton(this), *reject = new QPushButton(this); accept->setFlat(true); reject->setFlat(true); @@ -92,7 +96,7 @@ CallConfirmWidget::CallConfirmWidget(const QWidget* Anchor, const Friend& f) : layout->addWidget(callLabel); layout->addWidget(buttonBox); - setFixedSize(rectW,rectH+spikeH); + setFixedSize(rectW, rectH + spikeH); reposition(); } @@ -108,19 +112,20 @@ void CallConfirmWidget::reposition() parentWidget()->installEventFilter(this); QWidget* w = anchor->window(); - QPoint pos = anchor->mapToGlobal({(anchor->width()-rectW)/2,anchor->height()})-w->mapToGlobal({0,0}); + QPoint pos = anchor->mapToGlobal({(anchor->width() - rectW) / 2, anchor->height()}) + - w->mapToGlobal({0, 0}); // We don't want the widget to overflow past the right of the screen - int xOverflow=0; + int xOverflow = 0; if (pos.x() + rectW > w->width()) xOverflow = pos.x() + rectW - w->width(); pos.rx() -= xOverflow; - mainRect = {0,spikeH,rectW,rectH}; - brush = QBrush(QColor(65,65,65)); - spikePoly = QPolygon({{(rectW-spikeW)/2+xOverflow,spikeH}, - {rectW/2+xOverflow,0}, - {(rectW+spikeW)/2+xOverflow,spikeH}}); + mainRect = {0, spikeH, rectW, rectH}; + brush = QBrush(QColor(65, 65, 65)); + spikePoly = QPolygon({{(rectW - spikeW) / 2 + xOverflow, spikeH}, + {rectW / 2 + xOverflow, 0}, + {(rectW + spikeW) / 2 + xOverflow, spikeH}}); move(pos); update(); @@ -133,7 +138,7 @@ void CallConfirmWidget::paintEvent(QPaintEvent*) painter.setBrush(brush); painter.setPen(Qt::NoPen); - painter.drawRoundRect(mainRect, roundedFactor*rectRatio, roundedFactor); + painter.drawRoundRect(mainRect, roundedFactor * rectRatio, roundedFactor); painter.drawPolygon(spikePoly); } @@ -142,16 +147,16 @@ void CallConfirmWidget::showEvent(QShowEvent*) // If someone does show() from Widget or lower, the event will reach us // because it's our parent, and we could show up in the wrong form. // So check here if our friend's form is actually the active one. - //if (!Widget::getInstance()->isFriendWidgetCurActiveWidget(&f)) + // if (!Widget::getInstance()->isFriendWidgetCurActiveWidget(&f)) { - //QWidget::hide(); - //return; + // QWidget::hide(); + // return; } reposition(); update(); } -void CallConfirmWidget::hideEvent(QHideEvent *) +void CallConfirmWidget::hideEvent(QHideEvent*) { if (parentWidget()) parentWidget()->removeEventFilter(this); diff --git a/src/widget/tool/callconfirmwidget.h b/src/widget/tool/callconfirmwidget.h index 0d7808f9d..7a4aec885 100644 --- a/src/widget/tool/callconfirmwidget.h +++ b/src/widget/tool/callconfirmwidget.h @@ -21,10 +21,10 @@ #ifndef CALLCONFIRMWIDGET_H #define CALLCONFIRMWIDGET_H -#include -#include -#include #include +#include +#include +#include class QPaintEvent; class QShowEvent; @@ -47,7 +47,7 @@ protected: void paintEvent(QPaintEvent* event) final; void showEvent(QShowEvent* event) final; void hideEvent(QHideEvent* event) final; - bool eventFilter(QObject *, QEvent* event) final; + bool eventFilter(QObject*, QEvent* event) final; private: const QWidget* anchor; diff --git a/src/widget/tool/chattextedit.cpp b/src/widget/tool/chattextedit.cpp index 5cccb3dec..2ce72cf18 100644 --- a/src/widget/tool/chattextedit.cpp +++ b/src/widget/tool/chattextedit.cpp @@ -21,8 +21,8 @@ #include "src/widget/translator.h" #include -ChatTextEdit::ChatTextEdit(QWidget* parent) : - QTextEdit(parent) +ChatTextEdit::ChatTextEdit(QWidget* parent) + : QTextEdit(parent) { retranslateUi(); setAcceptRichText(false); @@ -36,29 +36,23 @@ ChatTextEdit::~ChatTextEdit() Translator::unregister(this); } -void ChatTextEdit::keyPressEvent(QKeyEvent * event) +void ChatTextEdit::keyPressEvent(QKeyEvent* event) { int key = event->key(); if ((key == Qt::Key_Enter || key == Qt::Key_Return) && !(event->modifiers() & Qt::ShiftModifier)) emit enterPressed(); - else if (key == Qt::Key_Tab) - { + else if (key == Qt::Key_Tab) { if (event->modifiers()) event->ignore(); - else - { + else { emit tabPressed(); event->ignore(); } - } - else if (key == Qt::Key_Up && this->toPlainText().isEmpty()) - { + } else if (key == Qt::Key_Up && this->toPlainText().isEmpty()) { this->setText(lastMessage); this->setFocus(); - this->moveCursor(QTextCursor::MoveOperation::End,QTextCursor::MoveMode::MoveAnchor); - } - else - { + this->moveCursor(QTextCursor::MoveOperation::End, QTextCursor::MoveMode::MoveAnchor); + } else { emit keyPressed(); QTextEdit::keyPressEvent(event); } @@ -74,7 +68,7 @@ void ChatTextEdit::retranslateUi() setPlaceholderText(tr("Type your message here...")); } -void ChatTextEdit::sendKeyEvent(QKeyEvent * event) +void ChatTextEdit::sendKeyEvent(QKeyEvent* event) { emit keyPressEvent(event); } diff --git a/src/widget/tool/chattextedit.h b/src/widget/tool/chattextedit.h index f93338eaf..8f77a51f4 100644 --- a/src/widget/tool/chattextedit.h +++ b/src/widget/tool/chattextedit.h @@ -29,7 +29,7 @@ public: explicit ChatTextEdit(QWidget* parent = 0); ~ChatTextEdit(); void setLastMessage(QString lm); - void sendKeyEvent(QKeyEvent * event); + void sendKeyEvent(QKeyEvent* event); signals: void enterPressed(); @@ -37,7 +37,7 @@ signals: void keyPressed(); protected: - virtual void keyPressEvent(QKeyEvent * event) final override; + virtual void keyPressEvent(QKeyEvent* event) final override; private: void retranslateUi(); diff --git a/src/widget/tool/croppinglabel.cpp b/src/widget/tool/croppinglabel.cpp index 8f0a0f35b..5f6146ee5 100644 --- a/src/widget/tool/croppinglabel.cpp +++ b/src/widget/tool/croppinglabel.cpp @@ -18,10 +18,10 @@ */ #include "croppinglabel.h" -#include -#include #include -#include +#include +#include +#include CroppingLabel::CroppingLabel(QWidget* parent) : QLabel(parent) @@ -34,15 +34,15 @@ CroppingLabel::CroppingLabel(QWidget* parent) class LineEdit : public QLineEdit { public: - explicit LineEdit(QWidget* parent = 0) : - QLineEdit(parent) - {} + explicit LineEdit(QWidget* parent = 0) + : QLineEdit(parent) + { + } protected: void keyPressEvent(QKeyEvent* event) override { - if (event->key() == Qt::Key_Escape) - { + if (event->key() == Qt::Key_Escape) { undo(); clearFocus(); } @@ -53,9 +53,7 @@ CroppingLabel::CroppingLabel(QWidget* parent) textEdit = new LineEdit(this); textEdit->hide(); - textEdit->setInputMethodHints(Qt::ImhNoAutoUppercase - | Qt::ImhNoPredictiveText - | Qt::ImhPreferLatin); + textEdit->setInputMethodHints(Qt::ImhNoAutoUppercase | Qt::ImhNoPredictiveText | Qt::ImhPreferLatin); connect(textEdit, &QLineEdit::editingFinished, this, &CroppingLabel::editingFinished); } @@ -105,7 +103,7 @@ QSize CroppingLabel::minimumSizeHint() const return QSize(fontMetrics().width("..."), QLabel::minimumSizeHint().height()); } -void CroppingLabel::mouseReleaseEvent(QMouseEvent *e) +void CroppingLabel::mouseReleaseEvent(QMouseEvent* e) { if (editable) showTextEdit(); @@ -117,8 +115,7 @@ void CroppingLabel::mouseReleaseEvent(QMouseEvent *e) void CroppingLabel::paintEvent(QPaintEvent* paintEvent) { - if (blockPaintEvents) - { + if (blockPaintEvents) { paintEvent->ignore(); return; } diff --git a/src/widget/tool/croppinglabel.h b/src/widget/tool/croppinglabel.h index a87344373..ab94ba803 100644 --- a/src/widget/tool/croppinglabel.h +++ b/src/widget/tool/croppinglabel.h @@ -51,10 +51,10 @@ protected: void setElidedText(); void hideTextEdit(); void showTextEdit(); - virtual void resizeEvent(QResizeEvent *ev) final override; + virtual void resizeEvent(QResizeEvent* ev) final override; virtual QSize sizeHint() const final override; virtual QSize minimumSizeHint() const final override; - virtual void mouseReleaseEvent(QMouseEvent *e) final override; + virtual void mouseReleaseEvent(QMouseEvent* e) final override; private slots: void editingFinished(); diff --git a/src/widget/tool/flyoutoverlaywidget.cpp b/src/widget/tool/flyoutoverlaywidget.cpp index 02d62d5c3..837ab2ea8 100644 --- a/src/widget/tool/flyoutoverlaywidget.cpp +++ b/src/widget/tool/flyoutoverlaywidget.cpp @@ -20,10 +20,10 @@ #include "flyoutoverlaywidget.h" -#include +#include #include #include -#include +#include #include FlyoutOverlayWidget::FlyoutOverlayWidget(QWidget* parent) @@ -39,12 +39,10 @@ FlyoutOverlayWidget::FlyoutOverlayWidget(QWidget* parent) connect(animation, &QAbstractAnimation::finished, this, &FlyoutOverlayWidget::finishedAnimation); setFlyoutPercent(0); hide(); - } FlyoutOverlayWidget::~FlyoutOverlayWidget() { - } int FlyoutOverlayWidget::animationDuration() const @@ -69,8 +67,7 @@ void FlyoutOverlayWidget::setFlyoutPercent(qreal progress) QSize self = size(); setMask(QRegion(0, 0, self.width() * progress + 1, self.height())); move(startPos.x() + self.width() - self.width() * percent, startPos.y()); - setVisible (progress != 0); - + setVisible(progress != 0); } bool FlyoutOverlayWidget::isShown() const @@ -114,7 +111,6 @@ void FlyoutOverlayWidget::finishedAnimation() // Delay it by a few frames to let the system catch up on rendering if (hide) QTimer::singleShot(50, this, SIGNAL(hidden())); - } void FlyoutOverlayWidget::startAnimation(bool forward) @@ -123,5 +119,4 @@ void FlyoutOverlayWidget::startAnimation(bool forward) animation->setDirection(forward ? QAbstractAnimation::Forward : QAbstractAnimation::Backward); animation->start(); animation->setCurrentTime(animation->duration() * percent); - } diff --git a/src/widget/tool/flyoutoverlaywidget.h b/src/widget/tool/flyoutoverlaywidget.h index f20a0a560..febd7b08f 100644 --- a/src/widget/tool/flyoutoverlaywidget.h +++ b/src/widget/tool/flyoutoverlaywidget.h @@ -51,15 +51,13 @@ signals: void hidden(); private: - void finishedAnimation(); void startAnimation(bool forward); QWidget* container; - QPropertyAnimation *animation; + QPropertyAnimation* animation; qreal percent = 1.0f; QPoint startPos; - }; #endif // FLYOUTOVERLAYWIDGET_HPP diff --git a/src/widget/tool/friendrequestdialog.cpp b/src/widget/tool/friendrequestdialog.cpp index d3363e20d..19b334e76 100644 --- a/src/widget/tool/friendrequestdialog.cpp +++ b/src/widget/tool/friendrequestdialog.cpp @@ -20,39 +20,39 @@ #include "friendrequestdialog.h" -#include #include #include #include #include #include +#include -FriendRequestDialog::FriendRequestDialog(QWidget* parent, const QString &userId, const QString &message) : - QDialog(parent) +FriendRequestDialog::FriendRequestDialog(QWidget* parent, const QString& userId, const QString& message) + : QDialog(parent) { setAttribute(Qt::WA_QuitOnClose, false); setWindowFlags(windowFlags() & ~Qt::WindowContextHelpButtonHint); - setWindowTitle(tr("Friend request","Title of the window to aceept/deny a friend request")); + setWindowTitle(tr("Friend request", "Title of the window to aceept/deny a friend request")); - QLabel *friendsLabel = new QLabel(tr("Someone wants to make friends with you"), this); - QLabel *userIdLabel = new QLabel(tr("User ID:"), this); - QLineEdit *userIdEdit = new QLineEdit(userId, this); + QLabel* friendsLabel = new QLabel(tr("Someone wants to make friends with you"), this); + QLabel* userIdLabel = new QLabel(tr("User ID:"), this); + QLineEdit* userIdEdit = new QLineEdit(userId, this); userIdEdit->setCursorPosition(0); userIdEdit->setReadOnly(true); - QLabel *messageLabel = new QLabel(tr("Friend request message:"), this); - QPlainTextEdit *messageEdit = new QPlainTextEdit(message, this); + QLabel* messageLabel = new QLabel(tr("Friend request message:"), this); + QPlainTextEdit* messageEdit = new QPlainTextEdit(message, this); messageEdit->setReadOnly(true); - QDialogButtonBox *buttonBox = new QDialogButtonBox(Qt::Horizontal, this); + QDialogButtonBox* buttonBox = new QDialogButtonBox(Qt::Horizontal, this); - buttonBox->addButton(tr("Accept","Accept a friend request"), QDialogButtonBox::AcceptRole); - buttonBox->addButton(tr("Reject","Reject a friend request"), QDialogButtonBox::RejectRole); + buttonBox->addButton(tr("Accept", "Accept a friend request"), QDialogButtonBox::AcceptRole); + buttonBox->addButton(tr("Reject", "Reject a friend request"), QDialogButtonBox::RejectRole); connect(buttonBox, &QDialogButtonBox::accepted, this, &FriendRequestDialog::accept); connect(buttonBox, &QDialogButtonBox::rejected, this, &FriendRequestDialog::reject); - QVBoxLayout *layout = new QVBoxLayout(this); + QVBoxLayout* layout = new QVBoxLayout(this); layout->addWidget(friendsLabel); layout->addSpacing(12); diff --git a/src/widget/tool/friendrequestdialog.h b/src/widget/tool/friendrequestdialog.h index 64fec0bda..7eff85e2b 100644 --- a/src/widget/tool/friendrequestdialog.h +++ b/src/widget/tool/friendrequestdialog.h @@ -1,8 +1,8 @@ /* Copyright (C) 2013 by Maxim Biro - + This file is part of Tox Qt GUI. - + This program is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or @@ -12,7 +12,7 @@ but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. - + You should have received a copy of the GNU General Public License along with qTox. If not, see . */ @@ -26,7 +26,7 @@ class FriendRequestDialog : public QDialog { Q_OBJECT public: - explicit FriendRequestDialog(QWidget* parent, const QString &userId, const QString &message); + explicit FriendRequestDialog(QWidget* parent, const QString& userId, const QString& message); }; #endif // FRIENDREQUESTDIALOG_HPP diff --git a/src/widget/tool/micfeedbackwidget.cpp b/src/widget/tool/micfeedbackwidget.cpp index 5f24a0358..20712e429 100644 --- a/src/widget/tool/micfeedbackwidget.cpp +++ b/src/widget/tool/micfeedbackwidget.cpp @@ -19,11 +19,12 @@ #include "micfeedbackwidget.h" #include "src/audio/audio.h" -#include #include +#include MicFeedbackWidget::MicFeedbackWidget(QWidget* parent) - : QWidget(parent), mMeterListener(nullptr) + : QWidget(parent) + , mMeterListener(nullptr) { setFixedHeight(20); } @@ -51,8 +52,7 @@ void MicFeedbackWidget::paintEvent(QPaintEvent*) const float slice = w / 5.f; const int padding = qRound(slice / 2); - for (int i = 0; i < 5; ++i) - { + for (int i = 0; i < 5; ++i) { int pos = qRound(slice * i + padding); painter.drawLine(pos, 2, pos, h - 4); } diff --git a/src/widget/tool/movablewidget.cpp b/src/widget/tool/movablewidget.cpp index 44d7213db..50d6614b6 100644 --- a/src/widget/tool/movablewidget.cpp +++ b/src/widget/tool/movablewidget.cpp @@ -18,8 +18,8 @@ */ #include "movablewidget.h" -#include #include +#include #include MovableWidget::MovableWidget(QWidget* parent) @@ -47,8 +47,7 @@ void MovableWidget::resetBoundary(QRect newBoundary) void MovableWidget::setBoundary(QRect newBoundary) { - if (boundaryRect.isNull()) - { + if (boundaryRect.isNull()) { boundaryRect = newBoundary; return; } @@ -57,7 +56,8 @@ void MovableWidget::setBoundary(QRect newBoundary) float changeY = newBoundary.height() / static_cast(boundaryRect.height()); float percentageX = (x() - boundaryRect.x()) / static_cast(boundaryRect.width() - width()); - float percentageY = (y() - boundaryRect.y()) / static_cast(boundaryRect.height() - height()); + float percentageY = + (y() - boundaryRect.y()) / static_cast(boundaryRect.height() - height()); actualSize.setWidth(actualSize.width() * changeX); actualSize.setHeight(actualSize.height() * changeY); @@ -70,14 +70,14 @@ void MovableWidget::setBoundary(QRect newBoundary) resize(QSize(round(actualSize.width()), round(actualSize.height()))); - actualPos = QPointF(percentageX * (newBoundary.width() - width()), percentageY * (newBoundary.height() - height())); + actualPos = QPointF(percentageX * (newBoundary.width() - width()), + percentageY * (newBoundary.height() - height())); actualPos += QPointF(newBoundary.topLeft()); QPoint moveTo = QPoint(round(actualPos.x()), round(actualPos.y())); move(moveTo); boundaryRect = newBoundary; - } float MovableWidget::getRatio() const @@ -99,8 +99,7 @@ void MovableWidget::setRatio(float r) void MovableWidget::mousePressEvent(QMouseEvent* event) { - if (event->buttons() & Qt::LeftButton) - { + if (event->buttons() & Qt::LeftButton) { if (!(mode & Resize)) mode |= Moving; @@ -110,8 +109,7 @@ void MovableWidget::mousePressEvent(QMouseEvent* event) void MovableWidget::mouseMoveEvent(QMouseEvent* event) { - if (mode & Moving) - { + if (mode & Moving) { QPoint moveTo = pos() - (lastPoint - event->globalPos()); checkBoundary(moveTo); @@ -119,11 +117,8 @@ void MovableWidget::mouseMoveEvent(QMouseEvent* event) lastPoint = event->globalPos(); actualPos = pos(); - } - else - { - if (!(event->buttons() & Qt::LeftButton)) - { + } else { + if (!(event->buttons() & Qt::LeftButton)) { if (event->x() < 6) mode |= ResizeLeft; else @@ -145,8 +140,7 @@ void MovableWidget::mouseMoveEvent(QMouseEvent* event) mode &= ~ResizeDown; } - if (mode & Resize) - { + if (mode & Resize) { const Modes ResizeUpRight = ResizeUp | ResizeRight; const Modes ResizeUpLeft = ResizeUp | ResizeLeft; const Modes ResizeDownRight = ResizeDown | ResizeRight; @@ -161,25 +155,23 @@ void MovableWidget::mouseMoveEvent(QMouseEvent* event) else setCursor(Qt::SizeVerCursor); - if (event->buttons() & Qt::LeftButton) - { + if (event->buttons() & Qt::LeftButton) { QPoint lastPosition = pos(); QPoint displacement = lastPoint - event->globalPos(); QSize lastSize = size(); - if (mode & ResizeUp) - { + if (mode & ResizeUp) { lastSize.setHeight(height() + displacement.y()); if (lastSize.height() > maximumHeight()) - lastPosition.setY(y() - displacement.y() + (lastSize.height() - maximumHeight())); + lastPosition.setY(y() - displacement.y() + + (lastSize.height() - maximumHeight())); else lastPosition.setY(y() - displacement.y()); } - if (mode & ResizeLeft) - { + if (mode & ResizeLeft) { lastSize.setWidth(width() + displacement.x()); if (lastSize.width() > maximumWidth()) lastPosition.setX(x() - displacement.x() + (lastSize.width() - maximumWidth())); @@ -199,10 +191,8 @@ void MovableWidget::mouseMoveEvent(QMouseEvent* event) if (lastSize.width() > maximumWidth()) lastSize.setWidth(maximumWidth()); - if (mode & (ResizeLeft | ResizeRight)) - { - if (mode & (ResizeUp | ResizeDown)) - { + if (mode & (ResizeLeft | ResizeRight)) { + if (mode & (ResizeUp | ResizeDown)) { int height = lastSize.width() / getRatio(); if (!(mode & ResizeDown)) @@ -215,14 +205,10 @@ void MovableWidget::mouseMoveEvent(QMouseEvent* event) if (height < minimumHeight()) lastPosition.setY(pos().y()); - } - else - { + } else { resize(lastSize.width(), lastSize.width() / getRatio()); } - } - else - { + } else { resize(lastSize.height() * getRatio(), lastSize.height()); } @@ -236,13 +222,10 @@ void MovableWidget::mouseMoveEvent(QMouseEvent* event) actualSize = size(); actualPos = pos(); } - } - else - { + } else { unsetCursor(); } } - } void MovableWidget::mouseReleaseEvent(QMouseEvent* event) @@ -256,14 +239,11 @@ void MovableWidget::mouseDoubleClickEvent(QMouseEvent* event) if (!(event->buttons() & Qt::LeftButton)) return; - if (!graphicsEffect()) - { + if (!graphicsEffect()) { QGraphicsOpacityEffect* opacityEffect = new QGraphicsOpacityEffect(this); opacityEffect->setOpacity(0.5); setGraphicsEffect(opacityEffect); - } - else - { + } else { setGraphicsEffect(nullptr); } } diff --git a/src/widget/tool/movablewidget.h b/src/widget/tool/movablewidget.h index dfe0cefcc..ff4e62d62 100644 --- a/src/widget/tool/movablewidget.h +++ b/src/widget/tool/movablewidget.h @@ -39,18 +39,18 @@ protected: private: void checkBoundary(QPoint& point) const; - void checkBoundaryLeft(int &x) const; + void checkBoundaryLeft(int& x) const; typedef uint8_t Modes; enum Mode : Modes { - Moving = 0x01, - ResizeLeft = 0x02, + Moving = 0x01, + ResizeLeft = 0x02, ResizeRight = 0x04, - ResizeUp = 0x08, - ResizeDown = 0x10, - Resize = ResizeLeft | ResizeRight | ResizeUp | ResizeDown + ResizeUp = 0x08, + ResizeDown = 0x10, + Resize = ResizeLeft | ResizeRight | ResizeUp | ResizeDown }; Modes mode = 0; diff --git a/src/widget/tool/profileimporter.cpp b/src/widget/tool/profileimporter.cpp index 6cfc4c93a..d75705922 100644 --- a/src/widget/tool/profileimporter.cpp +++ b/src/widget/tool/profileimporter.cpp @@ -35,9 +35,9 @@ * to create dialog forms. */ -ProfileImporter::ProfileImporter(QWidget* parent) : QWidget(parent) +ProfileImporter::ProfileImporter(QWidget* parent) + : QWidget(parent) { - } /** @@ -49,8 +49,8 @@ bool ProfileImporter::importProfile() QString title = tr("Import profile", "import dialog title"); QString filter = tr("Tox save file (*.tox)", "import dialog filter"); QString dir = QDir::homePath(); - QString path = QFileDialog::getOpenFileName(this, title, dir, filter, 0, - QFileDialog::DontUseNativeDialog); + QString path = + QFileDialog::getOpenFileName(this, title, dir, filter, 0, QFileDialog::DontUseNativeDialog); return importProfile(path); } @@ -79,43 +79,42 @@ bool ProfileImporter::askQuestion(QString title, QString message) * @param path Path to Tox profile. * @return True, if the import was succesful. False otherwise. */ -bool ProfileImporter::importProfile(const QString &path) +bool ProfileImporter::importProfile(const QString& path) { if (path.isEmpty()) - return false; + return false; QFileInfo info(path); - if (!info.exists()) - { - QMessageBox::warning(this, tr("File doesn't exist"), - tr("Profile doesn't exist"), QMessageBox::Ok); + if (!info.exists()) { + QMessageBox::warning(this, tr("File doesn't exist"), tr("Profile doesn't exist"), + QMessageBox::Ok); return false; } QString profile = info.completeBaseName(); - if (info.suffix() != "tox") - { + if (info.suffix() != "tox") { QMessageBox::warning(this, tr("Ignoring non-Tox file", "popup title"), tr("Warning: You have chosen a file that is not a " - "Tox save file; ignoring.", "popup text"), + "Tox save file; ignoring.", + "popup text"), QMessageBox::Ok); - return false; //ingore importing non-tox file + return false; // ingore importing non-tox file } QString settingsPath = Settings::getInstance().getSettingsDirPath(); QString profilePath = QDir(settingsPath).filePath(profile + Core::TOX_EXT); - if (QFileInfo(profilePath).exists()) - { + if (QFileInfo(profilePath).exists()) { QString title = tr("Profile already exists", "import confirm title"); QString message = tr("A profile named \"%1\" already exists. " "Do you want to erase it?", - "import confirm text").arg(profile); + "import confirm text") + .arg(profile); bool erase = askQuestion(title, message); if (!erase) - return false; //import canelled + return false; // import canelled QFile(profilePath).remove(); } @@ -123,9 +122,8 @@ bool ProfileImporter::importProfile(const QString &path) QFile::copy(path, profilePath); // no good way to update the ui from here... maybe we need a Widget:refreshUi() function... // such a thing would simplify other code as well I believe - QMessageBox::information(this, tr("Profile imported"), - tr("%1.tox was successfully imported").arg(profile), - QMessageBox::Ok); + QMessageBox::information(this, tr("Profile imported"), + tr("%1.tox was successfully imported").arg(profile), QMessageBox::Ok); - return true; //import successfull + return true; // import successfull } diff --git a/src/widget/tool/profileimporter.h b/src/widget/tool/profileimporter.h index 755b20e86..d3336902e 100644 --- a/src/widget/tool/profileimporter.h +++ b/src/widget/tool/profileimporter.h @@ -28,7 +28,7 @@ class ProfileImporter : public QWidget public: explicit ProfileImporter(QWidget* parent = 0); - bool importProfile(const QString &path); + bool importProfile(const QString& path); bool importProfile(); private: diff --git a/src/widget/tool/removefrienddialog.cpp b/src/widget/tool/removefrienddialog.cpp index c3e1b6ee4..e74ef3e23 100644 --- a/src/widget/tool/removefrienddialog.cpp +++ b/src/widget/tool/removefrienddialog.cpp @@ -10,7 +10,7 @@ RemoveFriendDialog::RemoveFriendDialog(QWidget* parent, const Friend* f) ui.setupUi(this); QString name = f->getDisplayedName().toHtmlEscaped(); QString text = tr("Are you sure you want to remove %1 from your contacts list?") - .arg(QString("%1").arg(name)); + .arg(QString("%1").arg(name)); ui.label->setText(text); auto removeButton = ui.buttonBox->button(QDialogButtonBox::Ok); diff --git a/src/widget/tool/removefrienddialog.h b/src/widget/tool/removefrienddialog.h index 389e1d582..b74ba0fb5 100644 --- a/src/widget/tool/removefrienddialog.h +++ b/src/widget/tool/removefrienddialog.h @@ -2,9 +2,9 @@ #define DELETEFRIENDDIALOG_H -#include #include "ui_removefrienddialog.h" #include "src/friend.h" +#include class RemoveFriendDialog : public QDialog diff --git a/src/widget/tool/screengrabberchooserrectitem.cpp b/src/widget/tool/screengrabberchooserrectitem.cpp index a7cb06d56..347075520 100644 --- a/src/widget/tool/screengrabberchooserrectitem.cpp +++ b/src/widget/tool/screengrabberchooserrectitem.cpp @@ -19,12 +19,13 @@ #include "screengrabberchooserrectitem.h" -#include -#include -#include #include +#include +#include +#include -enum { +enum +{ HandleSize = 10, MinRectSize = 2, }; @@ -55,18 +56,16 @@ ScreenGrabberChooserRectItem::ScreenGrabberChooserRectItem(QGraphicsScene* scene this->mainRect->setRect(QRect()); hideHandles(); - } ScreenGrabberChooserRectItem::~ScreenGrabberChooserRectItem() { - } QRectF ScreenGrabberChooserRectItem::boundingRect() const { - return QRectF(-HandleSize - 1, -HandleSize - 1, - rectWidth + HandleSize + 1, rectHeight + HandleSize + 1); + return QRectF(-HandleSize - 1, -HandleSize - 1, rectWidth + HandleSize + 1, + rectHeight + HandleSize + 1); } void ScreenGrabberChooserRectItem::beginResize(QPointF mousePos) @@ -83,15 +82,13 @@ void ScreenGrabberChooserRectItem::beginResize(QPointF mousePos) QRect ScreenGrabberChooserRectItem::chosenRect() const { - QRect rect (x(), y(), rectWidth, rectHeight); - if (rectWidth < 0) - { + QRect rect(x(), y(), rectWidth, rectHeight); + if (rectWidth < 0) { rect.setX(rect.x() + rectWidth); rect.setWidth(-rectWidth); } - if (rectHeight < 0) - { + if (rectHeight < 0) { rect.setY(rect.y() + rectHeight); rect.setHeight(-rectHeight); } @@ -125,33 +122,26 @@ void ScreenGrabberChooserRectItem::hideHandles() void ScreenGrabberChooserRectItem::mousePress(QGraphicsSceneMouseEvent* event) { - if (event->button() == Qt::LeftButton) - { + if (event->button() == Qt::LeftButton) { this->state = Moving; setCursor(QCursor(Qt::ClosedHandCursor)); } - } void ScreenGrabberChooserRectItem::mouseMove(QGraphicsSceneMouseEvent* event) { - if (this->state == Moving) - { + if (this->state == Moving) { QPointF delta = event->scenePos() - event->lastScenePos(); - moveBy (delta.x(), delta.y()); - } - else if (this->state == Resizing) - { + moveBy(delta.x(), delta.y()); + } else if (this->state == Resizing) { prepareGeometryChange(); QPointF size = event->scenePos() - scenePos(); - mainRect->setRect (0, 0, size.x(), size.y()); + mainRect->setRect(0, 0, size.x(), size.y()); rectWidth = size.x(); rectHeight = size.y(); updateHandlePositions(); - } - else - { + } else { return; } @@ -160,18 +150,14 @@ void ScreenGrabberChooserRectItem::mouseMove(QGraphicsSceneMouseEvent* event) void ScreenGrabberChooserRectItem::mouseRelease(QGraphicsSceneMouseEvent* event) { - if (event->button() == Qt::LeftButton) - { + if (event->button() == Qt::LeftButton) { setCursor(QCursor(Qt::OpenHandCursor)); QPointF delta = (event->scenePos() - startPos); - if (qAbs(delta.x()) < MinRectSize || qAbs(delta.y()) < MinRectSize) - { + if (qAbs(delta.x()) < MinRectSize || qAbs(delta.y()) < MinRectSize) { rectWidth = rectHeight = 0; mainRect->setRect(QRect()); - } - else - { + } else { QRect normalized = chosenRect(); rectWidth = normalized.width(); @@ -187,7 +173,6 @@ void ScreenGrabberChooserRectItem::mouseRelease(QGraphicsSceneMouseEvent* event) state = None; mainRect->ungrabMouse(); } - } void ScreenGrabberChooserRectItem::mouseDoubleClick(QGraphicsSceneMouseEvent* event) @@ -218,14 +203,12 @@ void ScreenGrabberChooserRectItem::mouseMoveHandle(int x, int y, QGraphicsSceneM bool increaseX = ((x < 0) == (delta.x() < 0)); bool increaseY = ((y < 0) == (delta.y() < 0)); - if ((delta.x() < 0 && increaseX) || (delta.x() >= 0 && !increaseX)) - { + if ((delta.x() < 0 && increaseX) || (delta.x() >= 0 && !increaseX)) { moveBy(delta.x(), 0); delta.rx() *= -1; } - if ((delta.y() < 0 && increaseY) || (delta.y() >= 0 && !increaseY)) - { + if ((delta.y() < 0 && increaseY) || (delta.y() >= 0 && !increaseY)) { moveBy(0, delta.y()); delta.ry() *= -1; } @@ -233,7 +216,7 @@ void ScreenGrabberChooserRectItem::mouseMoveHandle(int x, int y, QGraphicsSceneM // this->rectWidth += delta.x(); this->rectHeight += delta.y(); - this->mainRect->setRect (0, 0, this->rectWidth, this->rectHeight); + this->mainRect->setRect(0, 0, this->rectWidth, this->rectHeight); updateHandlePositions(); emit regionChosen(chosenRect()); } @@ -245,7 +228,6 @@ void ScreenGrabberChooserRectItem::mouseReleaseHandle(int x, int y, QGraphicsSce if (event->button() == Qt::LeftButton) this->state = None; - } QPoint ScreenGrabberChooserRectItem::getHandleMultiplier(QGraphicsItem* handle) @@ -316,8 +298,7 @@ void ScreenGrabberChooserRectItem::forwardMainRectEvent(QEvent* event) { QGraphicsSceneMouseEvent* mouseEvent = static_cast(event); - switch(event->type()) - { + switch (event->type()) { case QEvent::GraphicsSceneMousePress: return mousePress(mouseEvent); case QEvent::GraphicsSceneMouseMove: @@ -329,7 +310,6 @@ void ScreenGrabberChooserRectItem::forwardMainRectEvent(QEvent* event) default: return; } - } void ScreenGrabberChooserRectItem::forwardHandleEvent(QGraphicsItem* watched, QEvent* event) @@ -340,8 +320,7 @@ void ScreenGrabberChooserRectItem::forwardHandleEvent(QGraphicsItem* watched, QE if (multiplier.isNull()) return; - switch(event->type()) - { + switch (event->type()) { case QEvent::GraphicsSceneMousePress: return mousePressHandle(multiplier.x(), multiplier.y(), mouseEvent); case QEvent::GraphicsSceneMouseMove: @@ -351,5 +330,4 @@ void ScreenGrabberChooserRectItem::forwardHandleEvent(QGraphicsItem* watched, QE default: return; } - } diff --git a/src/widget/tool/screengrabberchooserrectitem.h b/src/widget/tool/screengrabberchooserrectitem.h index 8d7511d34..72f00f5ba 100644 --- a/src/widget/tool/screengrabberchooserrectitem.h +++ b/src/widget/tool/screengrabberchooserrectitem.h @@ -46,8 +46,8 @@ protected: virtual bool sceneEventFilter(QGraphicsItem* watched, QEvent* event) final override; private: - - enum State { + enum State + { None, Resizing, HandleResizing, @@ -85,9 +85,7 @@ private: QGraphicsRectItem* bottomCenter; QGraphicsRectItem* bottomLeft; QGraphicsRectItem* leftCenter; - }; - #endif // SCREENGRABBERCHOOSERRECTITEM_HPP diff --git a/src/widget/tool/screengrabberoverlayitem.cpp b/src/widget/tool/screengrabberoverlayitem.cpp index 2b0b7bb43..b6849a32f 100644 --- a/src/widget/tool/screengrabberoverlayitem.cpp +++ b/src/widget/tool/screengrabberoverlayitem.cpp @@ -35,12 +35,10 @@ ScreenGrabberOverlayItem::ScreenGrabberOverlayItem(ScreenshotGrabber* grabber) setCursor(QCursor(Qt::CrossCursor)); setBrush(overlayBrush); setPen(QPen(Qt::NoPen)); - } ScreenGrabberOverlayItem::~ScreenGrabberOverlayItem() { - } void ScreenGrabberOverlayItem::setChosenRect(QRect rect) @@ -54,7 +52,6 @@ void ScreenGrabberOverlayItem::mousePressEvent(QGraphicsSceneMouseEvent* event) { if (event->button() == Qt::LeftButton) this->screnshootGrabber->beginRectChooser(event); - } void ScreenGrabberOverlayItem::paint(QPainter* painter, const QStyleOptionGraphicsItem*, QWidget*) @@ -68,8 +65,9 @@ void ScreenGrabberOverlayItem::paint(QPainter* painter, const QStyleOptionGraphi qreal topY = chosenRect.y(); qreal bottomY = chosenRect.y() + chosenRect.height(); - painter->drawRect(0, 0, leftX, self.height()); // Left of chosen + painter->drawRect(0, 0, leftX, self.height()); // Left of chosen painter->drawRect(rightX, 0, self.width() - rightX, self.height()); // Right of chosen - painter->drawRect(leftX, 0, chosenRect.width(), topY); // Top of chosen - painter->drawRect(leftX, bottomY, chosenRect.width(), self.height() - bottomY); // Bottom of chosen + painter->drawRect(leftX, 0, chosenRect.width(), topY); // Top of chosen + painter->drawRect(leftX, bottomY, chosenRect.width(), + self.height() - bottomY); // Bottom of chosen } diff --git a/src/widget/tool/screengrabberoverlayitem.h b/src/widget/tool/screengrabberoverlayitem.h index 8f48f258b..3706b1d27 100644 --- a/src/widget/tool/screengrabberoverlayitem.h +++ b/src/widget/tool/screengrabberoverlayitem.h @@ -35,7 +35,8 @@ public: protected: virtual void mousePressEvent(QGraphicsSceneMouseEvent* event) final override; - virtual void paint(QPainter* painter, const QStyleOptionGraphicsItem* option, QWidget* widget) final override; + virtual void paint(QPainter* painter, const QStyleOptionGraphicsItem* option, + QWidget* widget) final override; private: ScreenshotGrabber* screnshootGrabber; diff --git a/src/widget/tool/screenshotgrabber.cpp b/src/widget/tool/screenshotgrabber.cpp index d6e20fc0b..fcf315a9d 100644 --- a/src/widget/tool/screenshotgrabber.cpp +++ b/src/widget/tool/screenshotgrabber.cpp @@ -41,7 +41,7 @@ ScreenshotGrabber::ScreenshotGrabber() , scene(0) , mQToxVisible(true) { - window = new QGraphicsView (scene); // Top-level widget + window = new QGraphicsView(scene); // Top-level widget window->setWindowFlags(Qt::FramelessWindowHint | Qt::BypassWindowManagerHint); window->setContentsMargins(0, 0, 0, 0); window->setHorizontalScrollBarPolicy(Qt::ScrollBarAlwaysOff); @@ -115,8 +115,7 @@ bool ScreenshotGrabber::handleKeyPress(QKeyEvent* event) window->hide(); QTimer::singleShot(350, this, SLOT(reInit())); - } - else + } else return false; return true; @@ -129,7 +128,8 @@ void ScreenshotGrabber::acceptRegion() return; // Scale the accepted region from DIPs to actual pixels - rect.setRect(rect.x() * pixRatio, rect.y() * pixRatio, rect.width() * pixRatio, rect.height() * pixRatio); + rect.setRect(rect.x() * pixRatio, rect.y() * pixRatio, rect.width() * pixRatio, + rect.height() * pixRatio); emit regionChosen(rect); qDebug() << "Screenshot accepted, chosen region" << rect; @@ -160,31 +160,34 @@ void ScreenshotGrabber::setupScene() this->helperTooltip->setDefaultTextColor(Qt::black); useNothingSelectedTooltip(); - connect(this->chooserRect, &ScreenGrabberChooserRectItem::doubleClicked, this, &ScreenshotGrabber::acceptRegion); - connect(this->chooserRect, &ScreenGrabberChooserRectItem::regionChosen, this, &ScreenshotGrabber::chooseHelperTooltipText); - connect(this->chooserRect, &ScreenGrabberChooserRectItem::regionChosen, this->overlay, &ScreenGrabberOverlayItem::setChosenRect); + connect(this->chooserRect, &ScreenGrabberChooserRectItem::doubleClicked, this, + &ScreenshotGrabber::acceptRegion); + connect(this->chooserRect, &ScreenGrabberChooserRectItem::regionChosen, this, + &ScreenshotGrabber::chooseHelperTooltipText); + connect(this->chooserRect, &ScreenGrabberChooserRectItem::regionChosen, this->overlay, + &ScreenGrabberOverlayItem::setChosenRect); } void ScreenshotGrabber::useNothingSelectedTooltip() { - helperTooltip->setHtml(tr("Click and drag to select a region. Press %1 to " - "hide/show qTox window, or %2 to cancel.", - "Help text shown when no region has been selected yet") - .arg(QString("%1").arg(tr("Space", "[Space] key on the keyboard")), - QString("%1").arg(tr("Escape", "[Escape] key on the keyboard"))) - ); + helperTooltip->setHtml( + tr("Click and drag to select a region. Press %1 to " + "hide/show qTox window, or %2 to cancel.", + "Help text shown when no region has been selected yet") + .arg(QString("%1").arg(tr("Space", "[Space] key on the keyboard")), + QString("%1").arg(tr("Escape", "[Escape] key on the keyboard")))); adjustTooltipPosition(); } void ScreenshotGrabber::useRegionSelectedTooltip() { - helperTooltip->setHtml(tr("Press %1 to send a screenshot of the selection, " - "%2 to hide/show qTox window, or %3 to cancel.", - "Help text shown when a region has been selected") - .arg(QString("%1").arg(tr("Enter", "[Enter] key on the keyboard")), - QString("%1").arg(tr("Space", "[Space] key on the keyboard")), - QString("%1").arg(tr("Escape", "[Escape] key on the keyboard"))) - ); + helperTooltip->setHtml( + tr("Press %1 to send a screenshot of the selection, " + "%2 to hide/show qTox window, or %3 to cancel.", + "Help text shown when a region has been selected") + .arg(QString("%1").arg(tr("Enter", "[Enter] key on the keyboard")), + QString("%1").arg(tr("Space", "[Space] key on the keyboard")), + QString("%1").arg(tr("Escape", "[Escape] key on the keyboard")))); adjustTooltipPosition(); } @@ -224,16 +227,13 @@ QPixmap ScreenshotGrabber::grabScreen() QRect rec = screen->virtualGeometry(); // Multiply by devicePixelRatio to get actual desktop size - return screen->grabWindow(QApplication::desktop()->winId(), - rec.x() * pixRatio, - rec.y() * pixRatio, - rec.width() * pixRatio, - rec.height() * pixRatio); + return screen->grabWindow(QApplication::desktop()->winId(), rec.x() * pixRatio, + rec.y() * pixRatio, rec.width() * pixRatio, rec.height() * pixRatio); } void ScreenshotGrabber::hideVisibleWindows() { - foreach(QWidget* w, qApp->topLevelWidgets()) { + foreach (QWidget* w, qApp->topLevelWidgets()) { if (w != window && w->isVisible()) { mHiddenWindows << w; w->setVisible(false); @@ -245,7 +245,7 @@ void ScreenshotGrabber::hideVisibleWindows() void ScreenshotGrabber::restoreHiddenWindows() { - foreach(QWidget* w, mHiddenWindows) { + foreach (QWidget* w, mHiddenWindows) { if (w) w->setVisible(true); } diff --git a/src/widget/tool/screenshotgrabber.h b/src/widget/tool/screenshotgrabber.h index aa9568d0e..302507a30 100644 --- a/src/widget/tool/screenshotgrabber.h +++ b/src/widget/tool/screenshotgrabber.h @@ -38,7 +38,6 @@ class ScreenshotGrabber : public QObject { Q_OBJECT public: - ScreenshotGrabber(); ~ScreenshotGrabber() override; @@ -51,7 +50,7 @@ public slots: void reInit(); signals: - void screenshotTaken(const QPixmap &pixmap); + void screenshotTaken(const QPixmap& pixmap); void regionChosen(QRect region); void rejected(); @@ -89,9 +88,8 @@ private: qreal pixRatio = 1.0; bool mQToxVisible; - QVector< QPointer > mHiddenWindows; + QVector> mHiddenWindows; }; #endif // SCREENSHOTGRABBER_H - diff --git a/src/widget/tool/toolboxgraphicsitem.cpp b/src/widget/tool/toolboxgraphicsitem.cpp index 1c7fb0052..dbb261308 100644 --- a/src/widget/tool/toolboxgraphicsitem.cpp +++ b/src/widget/tool/toolboxgraphicsitem.cpp @@ -34,7 +34,6 @@ ToolBoxGraphicsItem::ToolBoxGraphicsItem() ToolBoxGraphicsItem::~ToolBoxGraphicsItem() { - } void ToolBoxGraphicsItem::hoverEnterEvent(QGraphicsSceneHoverEvent* event) @@ -55,7 +54,8 @@ void ToolBoxGraphicsItem::startAnimation(QAbstractAnimation::Direction direction this->opacityAnimation->start(); } -void ToolBoxGraphicsItem::paint(QPainter* painter, const QStyleOptionGraphicsItem* option, QWidget* widget) +void ToolBoxGraphicsItem::paint(QPainter* painter, const QStyleOptionGraphicsItem* option, + QWidget* widget) { painter->save(); painter->setPen(Qt::NoPen); diff --git a/src/widget/tool/toolboxgraphicsitem.h b/src/widget/tool/toolboxgraphicsitem.h index 1d6be7118..dd92b0928 100644 --- a/src/widget/tool/toolboxgraphicsitem.h +++ b/src/widget/tool/toolboxgraphicsitem.h @@ -21,8 +21,8 @@ #define TOOLBOXGRAPHICSITEM_HPP #include -#include #include +#include class ToolBoxGraphicsItem final : public QObject, public QGraphicsItemGroup { @@ -32,14 +32,14 @@ public: ToolBoxGraphicsItem(); ~ToolBoxGraphicsItem(); - virtual void paint(QPainter* painter, const QStyleOptionGraphicsItem* option, QWidget* widget) final override; + virtual void paint(QPainter* painter, const QStyleOptionGraphicsItem* option, + QWidget* widget) final override; protected: virtual void hoverEnterEvent(QGraphicsSceneHoverEvent* event) final override; virtual void hoverLeaveEvent(QGraphicsSceneHoverEvent* event) final override; private: - void startAnimation(QAbstractAnimation::Direction direction); QPropertyAnimation* opacityAnimation; diff --git a/src/widget/translator.cpp b/src/widget/translator.cpp index 2702adbdb..bae8cb91d 100644 --- a/src/widget/translator.cpp +++ b/src/widget/translator.cpp @@ -21,12 +21,12 @@ #include "translator.h" #include "src/persistence/settings.h" #include -#include -#include -#include -#include #include +#include +#include #include +#include +#include #include QTranslator* Translator::translator{nullptr}; @@ -49,28 +49,21 @@ void Translator::translate() if ((locale = Settings::getInstance().getTranslation()).isEmpty()) locale = QLocale::system().name().section('_', 0, 0); - if (locale != "en") - { - if (translator->load(locale, ":translations/")) - { + if (locale != "en") { + if (translator->load(locale, ":translations/")) { qDebug() << "Loaded translation" << locale; // system menu translation - QTranslator *qtTranslator = new QTranslator(); - QString s_locale = "qt_"+locale; + QTranslator* qtTranslator = new QTranslator(); + QString s_locale = "qt_" + locale; QString location = QLibraryInfo::location(QLibraryInfo::TranslationsPath); - if (qtTranslator->load(s_locale, location)) - { + if (qtTranslator->load(s_locale, location)) { QApplication::installTranslator(qtTranslator); qDebug() << "System translation loaded" << locale; - } - else - { + } else { qDebug() << "System translation not loaded" << locale; } - } - else - { + } else { qDebug() << "Error loading translation" << locale; } QCoreApplication::installTranslator(translator); @@ -78,13 +71,12 @@ void Translator::translate() // After the language is changed from RTL to LTR, the layout direction isn't // always restored - const QString direction = QApplication::tr("LTR", - "Translate this string to the string 'RTL' in" - " right-to-left languages (for example Hebrew and" - " Arabic) to get proper widget layout"); + const QString direction = + QApplication::tr("LTR", "Translate this string to the string 'RTL' in" + " right-to-left languages (for example Hebrew and" + " Arabic) to get proper widget layout"); - QGuiApplication::setLayoutDirection( - direction == "RTL" ? Qt::RightToLeft : Qt::LeftToRight); + QGuiApplication::setLayoutDirection(direction == "RTL" ? Qt::RightToLeft : Qt::LeftToRight); for (auto pair : callbacks) pair.second(); @@ -95,7 +87,7 @@ void Translator::translate() * @param f Function, wich will called. * @param owner Widget to retanslate. */ -void Translator::registerHandler(std::function f, void *owner) +void Translator::registerHandler(std::function f, void* owner) { QMutexLocker locker{&lock}; callbacks.push_back({owner, f}); @@ -105,9 +97,10 @@ void Translator::registerHandler(std::function f, void *owner) * @brief Unregisters all handlers of an owner. * @param owner Owner to unregister. */ -void Translator::unregister(void *owner) +void Translator::unregister(void* owner) { QMutexLocker locker{&lock}; callbacks.erase(std::remove_if(begin(callbacks), end(callbacks), - [=](const Callback& c){return c.first==owner;}), end(callbacks)); + [=](const Callback& c) { return c.first == owner; }), + end(callbacks)); } diff --git a/src/widget/translator.h b/src/widget/translator.h index 39db38443..3ab0f0dc9 100644 --- a/src/widget/translator.h +++ b/src/widget/translator.h @@ -21,9 +21,9 @@ #ifndef TRANSLATOR_H #define TRANSLATOR_H -#include -#include #include +#include +#include #include class QTranslator; diff --git a/src/widget/widget.cpp b/src/widget/widget.cpp index 3312af654..9b2ad5d81 100644 --- a/src/widget/widget.cpp +++ b/src/widget/widget.cpp @@ -41,12 +41,13 @@ #include "circlewidget.h" #include "contentdialog.h" #include "contentlayout.h" -#include "form/groupchatform.h" #include "friendlistwidget.h" #include "friendwidget.h" #include "groupwidget.h" #include "maskablepixmapwidget.h" #include "splitterrestorer.h" +#include "systemtrayicon.h" +#include "form/groupchatform.h" #include "src/audio/audio.h" #include "src/core/core.h" #include "src/core/coreav.h" @@ -69,7 +70,6 @@ #include "src/widget/gui.h" #include "src/widget/style.h" #include "src/widget/translator.h" -#include "systemtrayicon.h" #include "tool/removefrienddialog.h" bool toxActivateEventHandler(const QByteArray&) @@ -83,16 +83,16 @@ bool toxActivateEventHandler(const QByteArray&) return true; } -Widget *Widget::instance{nullptr}; +Widget* Widget::instance{nullptr}; Widget::Widget(QWidget* parent) - : QMainWindow(parent), - icon{nullptr}, - trayMenu{nullptr}, - ui(new Ui::MainWindow), - activeChatroomWidget{nullptr}, - eventFlag(false), - eventIcon(false) + : QMainWindow(parent) + , icon{nullptr} + , trayMenu{nullptr} + , ui(new Ui::MainWindow) + , activeChatroomWidget{nullptr} + , eventFlag(false) + , eventIcon(false) { installEventFilter(this); Translator::translate(); @@ -103,8 +103,7 @@ void Widget::init() ui->setupUi(this); QIcon themeIcon = QIcon::fromTheme("qtox"); - if (!themeIcon.isNull()) - { + if (!themeIcon.isNull()) { setWindowIcon(themeIcon); } @@ -112,7 +111,7 @@ void Widget::init() timer->start(1000); offlineMsgTimer = new QTimer(); // FIXME: ↓ make a proper fix instead of increasing timeout into ∞ - offlineMsgTimer->start(2*60*1000); + offlineMsgTimer->start(2 * 60 * 1000); icon_size = 15; @@ -143,7 +142,8 @@ void Widget::init() connect(actionQuit, &QAction::triggered, qApp, &QApplication::quit); layout()->setContentsMargins(0, 0, 0, 0); - ui->friendList->setStyleSheet(Style::resolve(Style::getStylesheet(":/ui/friendList/friendList.css"))); + ui->friendList->setStyleSheet( + Style::resolve(Style::getStylesheet(":/ui/friendList/friendList.css"))); profilePicture = new MaskablePixmapWidget(this, QSize(40, 40), ":/img/avatar_mask.svg"); profilePicture->setPixmap(QPixmap(":/img/contact_dark.svg")); @@ -203,15 +203,15 @@ void Widget::init() ui->statusPanel->setStyleSheet(Style::getStylesheet(":/ui/window/statusPanel.css")); - QMenu *statusButtonMenu = new QMenu(ui->statusButton); + QMenu* statusButtonMenu = new QMenu(ui->statusButton); statusButtonMenu->addAction(statusOnline); statusButtonMenu->addAction(statusAway); statusButtonMenu->addAction(statusBusy); ui->statusButton->setMenu(statusButtonMenu); // disable proportional scaling - ui->mainSplitter->setStretchFactor(0,0); - ui->mainSplitter->setStretchFactor(1,1); + ui->mainSplitter->setStretchFactor(0, 0); + ui->mainSplitter->setStretchFactor(1, 1); onStatusSet(Status::Offline); @@ -227,7 +227,7 @@ void Widget::init() groupInviteForm = new GroupInviteForm; profileForm = new ProfileForm(); - //connect logout tray menu action + // connect logout tray menu action connect(actionLogout, &QAction::triggered, profileForm, &ProfileForm::onLogoutClicked); const Settings& s = Settings::getInstance(); @@ -282,10 +282,7 @@ void Widget::init() fileMenu->menu()->addSeparator(); logoutAction = fileMenu->menu()->addAction(QString()); - connect(logoutAction, &QAction::triggered, [this]() - { - Nexus::getInstance().showLogin(); - }); + connect(logoutAction, &QAction::triggered, [this]() { Nexus::getInstance().showLogin(); }); editMenu = globalMenu->insertMenu(viewMenu, new QMenu(this)); editMenu->menu()->addSeparator(); @@ -302,8 +299,7 @@ void Widget::init() nextConversationAction = new QAction(this); Nexus::getInstance().windowMenu->insertAction(frontAction, nextConversationAction); nextConversationAction->setShortcut(QKeySequence::SelectNextPage); - connect(nextConversationAction, &QAction::triggered, [this]() - { + connect(nextConversationAction, &QAction::triggered, [this]() { if (ContentDialog::current() == QApplication::activeWindow()) ContentDialog::current()->cycleContacts(true); else if (QApplication::activeWindow() == this) @@ -313,8 +309,7 @@ void Widget::init() previousConversationAction = new QAction(this); Nexus::getInstance().windowMenu->insertAction(frontAction, previousConversationAction); previousConversationAction->setShortcut(QKeySequence::SelectPreviousPage); - connect(previousConversationAction, &QAction::triggered, [this] - { + connect(previousConversationAction, &QAction::triggered, [this] { if (ContentDialog::current() == QApplication::activeWindow()) ContentDialog::current()->cycleContacts(false); else if (QApplication::activeWindow() == this) @@ -329,8 +324,7 @@ void Widget::init() QAction* aboutAction = viewMenu->menu()->addAction(QString()); aboutAction->setMenuRole(QAction::AboutRole); - connect(aboutAction, &QAction::triggered, [this]() - { + connect(aboutAction, &QAction::triggered, [this]() { onShowSettings(); settingsWidget->showAbout(); }); @@ -354,12 +348,11 @@ void Widget::init() ui->transferButton->setCheckable(true); ui->settingsButton->setCheckable(true); - if (contentLayout) - { + if (contentLayout) { onAddClicked(); } - //restore window state + // restore window state restoreGeometry(s.getWindowGeometry()); restoreState(s.getWindowState()); SplitterRestorer restorer(ui->mainSplitter); @@ -378,23 +371,21 @@ void Widget::init() connect(addFriendForm, &AddFriendForm::friendRequestsSeen, this, &Widget::friendRequestsUpdate); connect(addFriendForm, &AddFriendForm::friendRequestAccepted, this, &Widget::friendRequestAccepted); connect(groupInviteForm, &GroupInviteForm::groupInvitesSeen, this, &Widget::groupInvitesClear); - connect(groupInviteForm, &GroupInviteForm::groupInviteAccepted, this, &Widget::onGroupInviteAccepted); + connect(groupInviteForm, &GroupInviteForm::groupInviteAccepted, this, + &Widget::onGroupInviteAccepted); // settings - connect(&s, &Settings::showSystemTrayChanged, - this, &Widget::onSetShowSystemTray); - connect(&s, &Settings::separateWindowChanged, - this, &Widget::onSeparateWindowClicked); - connect(&s, &Settings::compactLayoutChanged, - contactListWidget, &FriendListWidget::onCompactChanged); - connect(&s, &Settings::groupchatPositionChanged, - contactListWidget, &FriendListWidget::onGroupchatPositionChanged); + connect(&s, &Settings::showSystemTrayChanged, this, &Widget::onSetShowSystemTray); + connect(&s, &Settings::separateWindowChanged, this, &Widget::onSeparateWindowClicked); + connect(&s, &Settings::compactLayoutChanged, contactListWidget, + &FriendListWidget::onCompactChanged); + connect(&s, &Settings::groupchatPositionChanged, contactListWidget, + &FriendListWidget::onGroupchatPositionChanged); retranslateUi(); Translator::registerHandler(std::bind(&Widget::retranslateUi, this), this); - if (!s.getShowSystemTray()) - { + if (!s.getShowSystemTray()) { show(); } @@ -403,13 +394,12 @@ void Widget::init() #endif } -bool Widget::eventFilter(QObject *obj, QEvent *event) +bool Widget::eventFilter(QObject* obj, QEvent* event) { - QWindowStateChangeEvent *ce = nullptr; + QWindowStateChangeEvent* ce = nullptr; Qt::WindowStates state = windowState(); - switch (event->type()) - { + switch (event->type()) { case QEvent::Close: // It's needed if user enable `Close to tray` wasMaximized = state.testFlag(Qt::WindowMaximized); @@ -417,13 +407,12 @@ bool Widget::eventFilter(QObject *obj, QEvent *event) case QEvent::WindowStateChange: ce = static_cast(event); - if (state.testFlag(Qt::WindowMinimized) && obj) - { + if (state.testFlag(Qt::WindowMinimized) && obj) { wasMaximized = ce->oldState().testFlag(Qt::WindowMaximized); } #ifdef Q_OS_MAC - emit windowStateChanged(windowState()); + emit windowStateChanged(windowState()); #endif break; default: @@ -435,21 +424,16 @@ bool Widget::eventFilter(QObject *obj, QEvent *event) void Widget::updateIcons() { - if (!icon) - { + if (!icon) { return; } QString status; - if (eventIcon) - { + if (eventIcon) { status = QStringLiteral("event"); - } - else - { + } else { status = ui->statusButton->property("status").toString(); - if (!status.length()) - { + if (!status.length()) { status = QStringLiteral("offline"); } } @@ -470,24 +454,20 @@ void Widget::updateIcons() static bool checkedHasThemeIcon = false; static bool hasThemeIconBug = false; - if (!checkedHasThemeIcon) - { + if (!checkedHasThemeIcon) { hasThemeIconBug = QIcon::hasThemeIcon("qtox-asjkdfhawjkeghdfjgh"); checkedHasThemeIcon = true; - if (hasThemeIconBug) - { - qDebug() << "Detected buggy QIcon::hasThemeIcon. Icon overrides from theme will be ignored."; + if (hasThemeIconBug) { + qDebug() + << "Detected buggy QIcon::hasThemeIcon. Icon overrides from theme will be ignored."; } } QIcon ico; - if (!hasThemeIconBug && QIcon::hasThemeIcon("qtox-" + status)) - { + if (!hasThemeIconBug && QIcon::hasThemeIcon("qtox-" + status)) { ico = QIcon::fromTheme("qtox-" + status); - } - else - { + } else { QString color = Settings::getInstance().getLightTrayIcon() ? "light" : "dark"; QString path = ":/img/taskbar/" + color + "/taskbar_" + status + ".svg"; QSvgRenderer renderer(path); @@ -501,8 +481,7 @@ void Widget::updateIcons() } setWindowIcon(ico); - if (icon) - { + if (icon) { icon->setIcon(ico); } } @@ -511,18 +490,15 @@ Widget::~Widget() { QWidgetList windowList = QApplication::topLevelWidgets(); - for (QWidget* window : windowList) - { - if (window != this) - { + for (QWidget* window : windowList) { + if (window != this) { window->close(); } } Translator::unregister(this); AutoUpdater::abortUpdates(); - if (icon) - { + if (icon) { icon->hide(); } @@ -547,8 +523,7 @@ Widget::~Widget() */ Widget* Widget::getInstance() { - if (!instance) - { + if (!instance) { instance = new Widget(); } @@ -564,10 +539,9 @@ void Widget::showUpdateDownloadProgress() settingsWidget->showAbout(); } -void Widget::moveEvent(QMoveEvent *event) +void Widget::moveEvent(QMoveEvent* event) { - if (event->type() == QEvent::Move) - { + if (event->type() == QEvent::Move) { saveWindowGeometry(); saveSplitterGeometry(); } @@ -575,16 +549,12 @@ void Widget::moveEvent(QMoveEvent *event) QWidget::moveEvent(event); } -void Widget::closeEvent(QCloseEvent *event) +void Widget::closeEvent(QCloseEvent* event) { - if (Settings::getInstance().getShowSystemTray() && Settings::getInstance().getCloseToTray()) - { + if (Settings::getInstance().getShowSystemTray() && Settings::getInstance().getCloseToTray()) { QWidget::closeEvent(event); - } - else - { - if (autoAwayActive) - { + } else { + if (autoAwayActive) { emit statusSet(Status::Online); autoAwayActive = false; } @@ -595,20 +565,17 @@ void Widget::closeEvent(QCloseEvent *event) } } -void Widget::changeEvent(QEvent *event) +void Widget::changeEvent(QEvent* event) { - if (event->type() == QEvent::WindowStateChange) - { - if (isMinimized() && - Settings::getInstance().getShowSystemTray() && - Settings::getInstance().getMinimizeToTray()) - { + if (event->type() == QEvent::WindowStateChange) { + if (isMinimized() && Settings::getInstance().getShowSystemTray() + && Settings::getInstance().getMinimizeToTray()) { this->hide(); } } } -void Widget::resizeEvent(QResizeEvent *event) +void Widget::resizeEvent(QResizeEvent* event) { Q_UNUSED(event); saveWindowGeometry(); @@ -641,7 +608,8 @@ void Widget::onDisconnected() void Widget::onFailedToStartCore() { QMessageBox critical(this); - critical.setText(tr("toxcore failed to start, the application will terminate after you close this message.")); + critical.setText(tr( + "toxcore failed to start, the application will terminate after you close this message.")); critical.setIcon(QMessageBox::Critical); critical.exec(); Nexus::getInstance().quit(); @@ -653,7 +621,8 @@ void Widget::onBadProxyCore() QMessageBox critical(this); critical.setText(tr("toxcore failed to start with your proxy settings. " "qTox cannot run; please modify your " - "settings and restart.", "popup text")); + "settings and restart.", + "popup text")); critical.setIcon(QMessageBox::Critical); critical.exec(); onShowSettings(); @@ -673,14 +642,11 @@ void Widget::onSeparateWindowClicked(bool separate) void Widget::onSeparateWindowChanged(bool separate, bool clicked) { - if (!separate) - { + if (!separate) { QWindowList windowList = QGuiApplication::topLevelWindows(); - for (QWindow* window : windowList) - { - if (window->objectName() == "detachedWindow") - { + for (QWindow* window : windowList) { + if (window->objectName() == "detachedWindow") { window->close(); } } @@ -692,21 +658,17 @@ void Widget::onSeparateWindowChanged(bool separate, bool clicked) setMinimumWidth(775); onAddClicked(); - } - else - { + } else { int width = ui->friendList->size().width(); QSize size; QPoint pos; - if (contentLayout) - { + if (contentLayout) { pos = mapToGlobal(ui->mainSplitter->widget(1)->pos()); size = ui->mainSplitter->widget(1)->size(); } - if (contentLayout) - { + if (contentLayout) { contentLayout->clear(); contentLayout->parentWidget()->setParent(0); // Remove from splitter. contentLayout->parentWidget()->hide(); @@ -717,13 +679,11 @@ void Widget::onSeparateWindowChanged(bool separate, bool clicked) setMinimumWidth(ui->tooliconsZone->sizeHint().width()); - if (clicked) - { + if (clicked) { showNormal(); resize(width, height()); - if (settingsWidget) - { + if (settingsWidget) { ContentLayout* contentLayout = createContentDialog((DialogType::SettingDialog)); contentLayout->parentWidget()->resize(size); contentLayout->parentWidget()->move(pos); @@ -739,15 +699,13 @@ void Widget::onSeparateWindowChanged(bool separate, bool clicked) void Widget::setWindowTitle(const QString& title) { - if (title.isEmpty()) - { + if (title.isEmpty()) { QMainWindow::setWindowTitle(QApplication::applicationName()); - } - else - { + } else { QString tmp = title; /// <[^>]*> Regexp to remove HTML tags, in case someone used them in title - QMainWindow::setWindowTitle(QApplication::applicationName() + QStringLiteral(" - ") + tmp.remove(QRegExp("<[^>]*>"))); + QMainWindow::setWindowTitle(QApplication::applicationName() + QStringLiteral(" - ") + + tmp.remove(QRegExp("<[^>]*>"))); } } @@ -760,17 +718,13 @@ void Widget::forceShow() void Widget::onAddClicked() { - if (Settings::getInstance().getSeparateWindow()) - { - if (!addFriendForm->isShown()) - { + if (Settings::getInstance().getSeparateWindow()) { + if (!addFriendForm->isShown()) { addFriendForm->show(createContentDialog(DialogType::AddDialog)); } setActiveToolMenuButton(ActiveToolMenuButton::None); - } - else - { + } else { hideMainForms(nullptr); addFriendForm->show(contentLayout); setWindowTitle(fromDialogType(DialogType::AddDialog)); @@ -780,17 +734,13 @@ void Widget::onAddClicked() void Widget::onGroupClicked() { - if (Settings::getInstance().getSeparateWindow()) - { - if (!groupInviteForm->isShown()) - { + if (Settings::getInstance().getSeparateWindow()) { + if (!groupInviteForm->isShown()) { groupInviteForm->show(createContentDialog(DialogType::GroupDialog)); } setActiveToolMenuButton(ActiveToolMenuButton::None); - } - else - { + } else { hideMainForms(nullptr); groupInviteForm->show(contentLayout); setWindowTitle(fromDialogType(DialogType::GroupDialog)); @@ -800,17 +750,13 @@ void Widget::onGroupClicked() void Widget::onTransferClicked() { - if (Settings::getInstance().getSeparateWindow()) - { - if (!filesForm->isShown()) - { + if (Settings::getInstance().getSeparateWindow()) { + if (!filesForm->isShown()) { filesForm->show(createContentDialog(DialogType::TransferDialog)); } setActiveToolMenuButton(ActiveToolMenuButton::None); - } - else - { + } else { hideMainForms(nullptr); filesForm->show(contentLayout); setWindowTitle(fromDialogType(DialogType::TransferDialog)); @@ -818,27 +764,32 @@ void Widget::onTransferClicked() } } -void Widget::confirmExecutableOpen(const QFileInfo &file) +void Widget::confirmExecutableOpen(const QFileInfo& file) { - static const QStringList dangerousExtensions = { "app", "bat", "com", "cpl", "dmg", "exe", "hta", "jar", "js", "jse", "lnk", "msc", "msh", "msh1", "msh1xml", "msh2", "msh2xml", "mshxml", "msi", "msp", "pif", "ps1", "ps1xml", "ps2", "ps2xml", "psc1", "psc2", "py", "reg", "scf", "sh", "src", "vb", "vbe", "vbs", "ws", "wsc", "wsf", "wsh" }; + static const QStringList dangerousExtensions = {"app", "bat", "com", "cpl", "dmg", + "exe", "hta", "jar", "js", "jse", + "lnk", "msc", "msh", "msh1", "msh1xml", + "msh2", "msh2xml", "mshxml", "msi", "msp", + "pif", "ps1", "ps1xml", "ps2", "ps2xml", + "psc1", "psc2", "py", "reg", "scf", + "sh", "src", "vb", "vbe", "vbs", + "ws", "wsc", "wsf", "wsh"}; - if (dangerousExtensions.contains(file.suffix())) - { - bool answer = GUI::askQuestion( - tr("Executable file", "popup title"), - tr("You have asked qTox to open an executable file. " - "Executable files can potentially damage your computer. " - "Are you sure want to open this file?", "popup text"), - false, true); - if (!answer) - { + if (dangerousExtensions.contains(file.suffix())) { + bool answer = GUI::askQuestion(tr("Executable file", "popup title"), + tr("You have asked qTox to open an executable file. " + "Executable files can potentially damage your computer. " + "Are you sure want to open this file?", + "popup text"), + false, true); + if (!answer) { return; } // The user wants to run this file, so make it executable and run it - QFile(file.filePath()).setPermissions(file.permissions() - | QFile::ExeOwner | QFile::ExeUser - | QFile::ExeGroup | QFile::ExeOther); + QFile(file.filePath()) + .setPermissions(file.permissions() | QFile::ExeOwner | QFile::ExeUser | QFile::ExeGroup + | QFile::ExeOther); } QDesktopServices::openUrl(QUrl::fromLocalFile(file.filePath())); @@ -846,35 +797,23 @@ void Widget::confirmExecutableOpen(const QFileInfo &file) void Widget::onIconClick(QSystemTrayIcon::ActivationReason reason) { - if (reason == QSystemTrayIcon::Trigger) - { - if (isHidden() || isMinimized()) - { - if (wasMaximized) - { + if (reason == QSystemTrayIcon::Trigger) { + if (isHidden() || isMinimized()) { + if (wasMaximized) { showMaximized(); - } - else - { + } else { showNormal(); } activateWindow(); - } - else if (!isActiveWindow()) - { + } else if (!isActiveWindow()) { activateWindow(); - } - else - { + } else { wasMaximized = isMaximized(); hide(); } - } - else if (reason == QSystemTrayIcon::Unknown) - { - if (isHidden()) - { + } else if (reason == QSystemTrayIcon::Unknown) { + if (isHidden()) { forceShow(); } } @@ -882,23 +821,18 @@ void Widget::onIconClick(QSystemTrayIcon::ActivationReason reason) void Widget::onShowSettings() { - if (!settingsWidget) - { + if (!settingsWidget) { settingsWidget = new SettingsWidget(this); } - if (Settings::getInstance().getSeparateWindow()) - { - if (!settingsWidget->isShown()) - { + if (Settings::getInstance().getSeparateWindow()) { + if (!settingsWidget->isShown()) { settingsWidget->show(createContentDialog(DialogType::SettingDialog)); } setActiveToolMenuButton(ActiveToolMenuButton::None); settingsWidget->setWindowIcon(QIcon(":/img/icons/qtox.svg")); - } - else - { + } else { hideMainForms(nullptr); settingsWidget->show(contentLayout); setWindowTitle(fromDialogType(DialogType::SettingDialog)); @@ -908,18 +842,14 @@ void Widget::onShowSettings() void Widget::showProfile() // onAvatarClicked, onUsernameClicked { - if (Settings::getInstance().getSeparateWindow()) - { - if (!profileForm->isShown()) - { + if (Settings::getInstance().getSeparateWindow()) { + if (!profileForm->isShown()) { profileForm->show(createContentDialog(DialogType::ProfileDialog)); } setActiveToolMenuButton(ActiveToolMenuButton::None); settingsWidget->setWindowIcon(QIcon(":/img/icons/qtox.svg")); - } - else - { + } else { hideMainForms(nullptr); profileForm->show(contentLayout); setWindowTitle(fromDialogType(DialogType::ProfileDialog)); @@ -931,13 +861,11 @@ void Widget::hideMainForms(GenericChatroomWidget* chatroomWidget) { setActiveToolMenuButton(ActiveToolMenuButton::None); - if (contentLayout != nullptr) - { + if (contentLayout != nullptr) { contentLayout->clear(); } - if (activeChatroomWidget != nullptr) - { + if (activeChatroomWidget != nullptr) { activeChatroomWidget->setAsInactiveChatroom(); } @@ -946,15 +874,13 @@ void Widget::hideMainForms(GenericChatroomWidget* chatroomWidget) void Widget::setUsername(const QString& username) { - if (username.isEmpty()) - { + if (username.isEmpty()) { ui->nameLabel->setText(tr("Your name")); ui->nameLabel->setToolTip(tr("Your name")); - } - else - { + } else { ui->nameLabel->setText(username); - ui->nameLabel->setToolTip(Qt::convertFromPlainText(username, Qt::WhiteSpaceNormal)); // for overlength names + ui->nameLabel->setToolTip( + Qt::convertFromPlainText(username, Qt::WhiteSpaceNormal)); // for overlength names } QString sanename = username; @@ -971,27 +897,22 @@ void Widget::onStatusMessageChanged(const QString& newStatusMessage) void Widget::setStatusMessage(const QString& statusMessage) { - if (statusMessage.isEmpty()) - { + if (statusMessage.isEmpty()) { ui->statusLabel->setText(tr("Your status")); ui->statusLabel->setToolTip(tr("Your status")); - } - else - { + } else { ui->statusLabel->setText(statusMessage); // escape HTML from tooltips and preserve newlines // TODO: move newspace preservance to a generic function - ui->statusLabel->setToolTip("

" + - statusMessage.toHtmlEscaped() + - "

"); + ui->statusLabel->setToolTip("

" + statusMessage.toHtmlEscaped() + + "

"); } } void Widget::reloadHistory() { QDateTime weekAgo = QDateTime::currentDateTime().addDays(-7); - for (auto f : FriendList::getAllFriends()) - { + for (auto f : FriendList::getAllFriends()) { f->getChatForm()->loadHistory(weekAgo, true); } } @@ -1011,39 +932,28 @@ void Widget::addFriend(int friendId, const ToxPk& friendPk) QDate activityDate = s.getFriendActivity(friendPk); QDate chatDate = friendForm->getLatestDate(); - if (chatDate > activityDate && chatDate.isValid()) - { + if (chatDate > activityDate && chatDate.isValid()) { Settings::getInstance().setFriendActivity(friendPk, chatDate); } contactListWidget->addFriendWidget(widget, Status::Offline, s.getFriendCircleID(friendPk)); - connect(newfriend, &Friend::aliasChanged, - this, &Widget::onFriendAliasChanged); - connect(newfriend, &Friend::nameChanged, - this, &Widget::onFriendAliasChanged); + connect(newfriend, &Friend::aliasChanged, this, &Widget::onFriendAliasChanged); + connect(newfriend, &Friend::nameChanged, this, &Widget::onFriendAliasChanged); - connect(widget, &FriendWidget::chatroomWidgetClicked, - this, &Widget::onChatroomWidgetClicked); - connect(widget, &FriendWidget::chatroomWidgetClicked, - friendForm, &ChatForm::focusInput); - connect(widget, &FriendWidget::copyFriendIdToClipboard, - this, &Widget::copyFriendIdToClipboard); - connect(widget, &FriendWidget::contextMenuCalled, - widget, &FriendWidget::onContextMenuCalled); - connect(widget, SIGNAL(removeFriend(int)), - this, SLOT(removeFriend(int))); + connect(widget, &FriendWidget::chatroomWidgetClicked, this, &Widget::onChatroomWidgetClicked); + connect(widget, &FriendWidget::chatroomWidgetClicked, friendForm, &ChatForm::focusInput); + connect(widget, &FriendWidget::copyFriendIdToClipboard, this, &Widget::copyFriendIdToClipboard); + connect(widget, &FriendWidget::contextMenuCalled, widget, &FriendWidget::onContextMenuCalled); + connect(widget, SIGNAL(removeFriend(int)), this, SLOT(removeFriend(int))); Core* core = Core::getInstance(); - connect(core, &Core::friendAvatarChanged, - widget, &FriendWidget::onAvatarChange); - connect(core, &Core::friendAvatarRemoved, - widget, &FriendWidget::onAvatarRemoved); + connect(core, &Core::friendAvatarChanged, widget, &FriendWidget::onAvatarChange); + connect(core, &Core::friendAvatarRemoved, widget, &FriendWidget::onAvatarRemoved); // Try to get the avatar from the cache QPixmap avatar = Nexus::getProfile()->loadAvatar(friendPk.toString()); - if (!avatar.isNull()) - { + if (!avatar.isNull()) { friendForm->onAvatarChange(friendId, avatar); widget->onAvatarChange(friendId, avatar); } @@ -1055,12 +965,11 @@ void Widget::addFriend(int friendId, const ToxPk& friendPk) void Widget::addFriendFailed(const ToxPk&, const QString& errorInfo) { QString info = QString(tr("Couldn't request friendship")); - if (!errorInfo.isEmpty()) - { + if (!errorInfo.isEmpty()) { info = info + QStringLiteral(": ") + errorInfo; } - QMessageBox::critical(0,"Error",info); + QMessageBox::critical(0, "Error", info); } void Widget::onFriendshipChanged(int friendId) @@ -1072,30 +981,24 @@ void Widget::onFriendshipChanged(int friendId) void Widget::onFriendStatusChanged(int friendId, Status status) { Friend* f = FriendList::findFriend(friendId); - if (!f) - { + if (!f) { return; } bool isActualChange = f->getStatus() != status; FriendWidget* widget = friendWidgets[friendId]; - if (isActualChange) - { - if (f->getStatus() == Status::Offline) - { + if (isActualChange) { + if (f->getStatus() == Status::Offline) { contactListWidget->moveWidget(widget, Status::Online); - } - else if (status == Status::Offline) - { + } else if (status == Status::Offline) { contactListWidget->moveWidget(widget, Status::Offline); } } f->setStatus(status); widget->updateStatusLight(); - if (widget->isActive()) - { + if (widget->isActive()) { setWindowTitle(widget->getTitle()); } @@ -1105,8 +1008,7 @@ void Widget::onFriendStatusChanged(int friendId, Status status) void Widget::onFriendStatusMessageChanged(int friendId, const QString& message) { Friend* f = FriendList::findFriend(friendId); - if (!f) - { + if (!f) { return; } @@ -1123,8 +1025,7 @@ void Widget::onFriendStatusMessageChanged(int friendId, const QString& message) void Widget::onFriendUsernameChanged(int friendId, const QString& username) { Friend* f = FriendList::findFriend(friendId); - if (!f) - { + if (!f) { return; } @@ -1135,73 +1036,61 @@ void Widget::onFriendUsernameChanged(int friendId, const QString& username) void Widget::onFriendAliasChanged(uint32_t friendId, const QString& alias) { - Friend *f = FriendList::findFriend(friendId); - FriendWidget *friendWidget = friendWidgets[friendId]; + Friend* f = FriendList::findFriend(friendId); + FriendWidget* friendWidget = friendWidgets[friendId]; friendWidget->setName(alias); - if (friendWidget->isActive()) - { + if (friendWidget->isActive()) { GUI::setWindowTitle(alias); } Status s = f->getStatus(); contactListWidget->moveWidget(friendWidget, s); FilterCriteria criteria = getFilterCriteria(); - bool filter = s == Status::Offline ? filterOffline(criteria) - : filterOnline(criteria); + bool filter = s == Status::Offline ? filterOffline(criteria) : filterOnline(criteria); friendWidget->searchName(ui->searchContactText->text(), filter); ChatForm* friendForm = f->getChatForm(); friendForm->setName(alias); - for (Group *g : GroupList::getAllGroups()) - { + for (Group* g : GroupList::getAllGroups()) { g->regeneratePeerList(); } } -void Widget::onChatroomWidgetClicked(GenericChatroomWidget *widget, bool group) +void Widget::onChatroomWidgetClicked(GenericChatroomWidget* widget, bool group) { widget->resetEventFlags(); widget->updateStatusLight(); - if (widget->chatFormIsSet(true) && !group) - { + if (widget->chatFormIsSet(true) && !group) { return; } - if (Settings::getInstance().getSeparateWindow() || group) - { + if (Settings::getInstance().getSeparateWindow() || group) { ContentDialog* dialog = nullptr; - if (!Settings::getInstance().getDontGroupWindows() && !group) - { + if (!Settings::getInstance().getDontGroupWindows() && !group) { dialog = ContentDialog::current(); } - if (dialog == nullptr) - { + if (dialog == nullptr) { dialog = createContentDialog(); } dialog->show(); Friend* frnd = widget->getFriend(); - if (frnd != nullptr) - { + if (frnd != nullptr) { addFriendDialog(frnd, dialog); - } - else - { + } else { Group* group = widget->getGroup(); addGroupDialog(group, dialog); } dialog->raise(); dialog->activateWindow(); - } - else - { + } else { hideMainForms(widget); widget->setChatForm(contentLayout); widget->setAsActiveChatroom(); @@ -1212,25 +1101,20 @@ void Widget::onChatroomWidgetClicked(GenericChatroomWidget *widget, bool group) void Widget::onFriendMessageReceived(int friendId, const QString& message, bool isAction) { Friend* f = FriendList::findFriend(friendId); - if (!f) - { + if (!f) { return; } QDateTime timestamp = QDateTime::currentDateTime(); Profile* profile = Nexus::getProfile(); - if (profile->isHistoryEnabled()) - { + if (profile->isHistoryEnabled()) { QString publicKey = f->getPublicKey().toString(); QString name = f->getDisplayedName(); QString text = message; - if (isAction) - { + if (isAction) { text = ChatForm::ACTION_PREFIX + f->getDisplayedName() + " " + text; } - profile->getHistory()->addNewMessage(publicKey, text, - publicKey, timestamp, - true, name); + profile->getHistory()->addNewMessage(publicKey, text, publicKey, timestamp, true, name); } newFriendMessageAlert(friendId); @@ -1239,22 +1123,20 @@ void Widget::onFriendMessageReceived(int friendId, const QString& message, bool void Widget::onReceiptRecieved(int friendId, int receipt) { Friend* f = FriendList::findFriend(friendId); - if (!f) - { + if (!f) { return; } f->getChatForm()->getOfflineMsgEngine()->dischargeReceipt(receipt); } -void Widget::addFriendDialog(Friend* frnd, ContentDialog *dialog) +void Widget::addFriendDialog(Friend* frnd, ContentDialog* dialog) { - ContentDialog *contentDialog = ContentDialog::getFriendDialog(frnd->getFriendId()); + ContentDialog* contentDialog = ContentDialog::getFriendDialog(frnd->getFriendId()); bool isSeparate = Settings::getInstance().getSeparateWindow(); FriendWidget* widget = friendWidgets[frnd->getFriendId()]; bool isCurrent = activeChatroomWidget == widget; - if (!contentDialog && !isSeparate && isCurrent) - { + if (!contentDialog && !isSeparate && isCurrent) { onAddClicked(); } @@ -1262,69 +1144,58 @@ void Widget::addFriendDialog(Friend* frnd, ContentDialog *dialog) friendWidget->setStatusMsg(widget->getStatusMsg()); - connect(friendWidget, SIGNAL(removeFriend(int)), - this, SLOT(removeFriend(int))); - connect(friendWidget, &FriendWidget::copyFriendIdToClipboard, - this, &Widget::copyFriendIdToClipboard); + connect(friendWidget, SIGNAL(removeFriend(int)), this, SLOT(removeFriend(int))); + connect(friendWidget, &FriendWidget::copyFriendIdToClipboard, this, + &Widget::copyFriendIdToClipboard); // Signal transmission from the created `friendWidget` (which shown in // ContentDialog) to the `widget` (which shown in main widget) // FIXME: emit should be removed - connect(friendWidget, &FriendWidget::contextMenuCalled, - widget, [=](QContextMenuEvent * event) - { - emit widget->contextMenuCalled(event); - }); + connect(friendWidget, &FriendWidget::contextMenuCalled, widget, + [=](QContextMenuEvent* event) { emit widget->contextMenuCalled(event); }); - connect(friendWidget, &FriendWidget::chatroomWidgetClicked, - this, [=](GenericChatroomWidget *w, bool group) - { - Q_UNUSED(w); - emit widget->chatroomWidgetClicked(widget, group); - }); + connect(friendWidget, &FriendWidget::chatroomWidgetClicked, this, + [=](GenericChatroomWidget* w, bool group) { + Q_UNUSED(w); + emit widget->chatroomWidgetClicked(widget, group); + }); // FIXME: emit should be removed emit widget->chatroomWidgetClicked(widget, false); Core* core = Core::getInstance(); - connect(core, &Core::friendAvatarChanged, - friendWidget, &FriendWidget::onAvatarChange); - connect(core, &Core::friendAvatarRemoved, - friendWidget, &FriendWidget::onAvatarRemoved); + connect(core, &Core::friendAvatarChanged, friendWidget, &FriendWidget::onAvatarChange); + connect(core, &Core::friendAvatarRemoved, friendWidget, &FriendWidget::onAvatarRemoved); QPixmap avatar = Nexus::getProfile()->loadAvatar(frnd->getPublicKey().toString()); - if (!avatar.isNull()) - { + if (!avatar.isNull()) { friendWidget->onAvatarChange(frnd->getFriendId(), avatar); } } -void Widget::addGroupDialog(Group *group, ContentDialog *dialog) +void Widget::addGroupDialog(Group* group, ContentDialog* dialog) { int groupId = group->getGroupId(); ContentDialog* groupDialog = ContentDialog::getGroupDialog(groupId); bool separated = Settings::getInstance().getSeparateWindow(); GroupWidget* widget = group->getGroupWidget(); bool isCurrentWindow = activeChatroomWidget == widget; - if (!groupDialog && !separated && isCurrentWindow) - { + if (!groupDialog && !separated && isCurrentWindow) { onAddClicked(); } GroupWidget* groupWidget = dialog->addGroup(groupId, group->getName()); - connect(groupWidget, SIGNAL(removeGroup(int)), - this, SLOT(removeGroup(int))); - connect(groupWidget, &GroupWidget::chatroomWidgetClicked, - group->getChatForm(), &ChatForm::focusInput); + connect(groupWidget, SIGNAL(removeGroup(int)), this, SLOT(removeGroup(int))); + connect(groupWidget, &GroupWidget::chatroomWidgetClicked, group->getChatForm(), + &ChatForm::focusInput); // Signal transmission from the created `groupWidget` (which shown in // ContentDialog) to the `widget` (which shown in main widget) // FIXME: emit should be removed - connect(groupWidget, &GroupWidget::chatroomWidgetClicked, - this, [=](GenericChatroomWidget *w, bool group) - { - Q_UNUSED(w); - emit widget->chatroomWidgetClicked(widget, group); - }); + connect(groupWidget, &GroupWidget::chatroomWidgetClicked, this, + [=](GenericChatroomWidget* w, bool group) { + Q_UNUSED(w); + emit widget->chatroomWidgetClicked(widget, group); + }); // FIXME: emit should be removed emit widget->chatroomWidgetClicked(widget, false); @@ -1337,24 +1208,16 @@ bool Widget::newFriendMessageAlert(int friendId, bool sound) ContentDialog* contentDialog = ContentDialog::getFriendDialog(friendId); Friend* f = FriendList::findFriend(friendId); - if (contentDialog != nullptr) - { + if (contentDialog != nullptr) { currentWindow = contentDialog->window(); hasActive = ContentDialog::isFriendWidgetActive(friendId); - } - else - { - if (Settings::getInstance().getSeparateWindow() && Settings::getInstance().getShowWindow()) - { - if (Settings::getInstance().getDontGroupWindows()) - { + } else { + if (Settings::getInstance().getSeparateWindow() && Settings::getInstance().getShowWindow()) { + if (Settings::getInstance().getDontGroupWindows()) { contentDialog = createContentDialog(); - } - else - { + } else { contentDialog = ContentDialog::current(); - if (!contentDialog) - { + if (!contentDialog) { contentDialog = createContentDialog(); } } @@ -1362,31 +1225,24 @@ bool Widget::newFriendMessageAlert(int friendId, bool sound) addFriendDialog(f, contentDialog); currentWindow = contentDialog->window(); hasActive = ContentDialog::isFriendWidgetActive(friendId); - } - else - { + } else { currentWindow = window(); FriendWidget* widget = friendWidgets[friendId]; hasActive = widget == activeChatroomWidget; } } - if (newMessageAlert(currentWindow, hasActive, sound)) - { + if (newMessageAlert(currentWindow, hasActive, sound)) { FriendWidget* widget = friendWidgets[friendId]; f->setEventFlag(true); widget->updateStatusLight(); ui->friendList->trackWidget(widget); - if (contentDialog == nullptr) - { - if (hasActive) - { + if (contentDialog == nullptr) { + if (hasActive) { setWindowTitle(widget->getTitle()); } - } - else - { + } else { ContentDialog::updateFriendStatus(friendId); } @@ -1401,36 +1257,28 @@ bool Widget::newGroupMessageAlert(int groupId, bool notify) bool hasActive; QWidget* currentWindow; ContentDialog* contentDialog = ContentDialog::getGroupDialog(groupId); - Group* g = GroupList::findGroup(groupId); + Group* g = GroupList::findGroup(groupId); - if (contentDialog != nullptr) - { + if (contentDialog != nullptr) { currentWindow = contentDialog->window(); hasActive = ContentDialog::isGroupWidgetActive(groupId); - } - else - { + } else { currentWindow = window(); hasActive = g->getGroupWidget() == activeChatroomWidget; } - if (!newMessageAlert(currentWindow, hasActive, true, notify)) - { + if (!newMessageAlert(currentWindow, hasActive, true, notify)) { return false; } g->setEventFlag(true); g->getGroupWidget()->updateStatusLight(); - if (contentDialog == nullptr) - { - if (hasActive) - { + if (contentDialog == nullptr) { + if (hasActive) { setWindowTitle(g->getGroupWidget()->getTitle()); } - } - else - { + } else { ContentDialog::updateGroupStatus(groupId); } @@ -1439,8 +1287,7 @@ bool Widget::newGroupMessageAlert(int groupId, bool notify) QString Widget::fromDialogType(DialogType type) { - switch (type) - { + switch (type) { case DialogType::AddDialog: return tr("Add friend", "title of the window"); case DialogType::GroupDialog: @@ -1461,24 +1308,19 @@ bool Widget::newMessageAlert(QWidget* currentWindow, bool isActive, bool sound, { bool inactiveWindow = isMinimized() || !currentWindow->isActiveWindow(); - if (!inactiveWindow && isActive) - { + if (!inactiveWindow && isActive) { return false; } - if (notify) - { - if (inactiveWindow) - { + if (notify) { + if (inactiveWindow) { QApplication::alert(currentWindow); eventFlag = true; } - if (Settings::getInstance().getShowWindow()) - { + if (Settings::getInstance().getShowWindow()) { currentWindow->show(); - if (inactiveWindow && Settings::getInstance().getShowInFront()) - { + if (inactiveWindow && Settings::getInstance().getShowInFront()) { currentWindow->activateWindow(); } } @@ -1487,8 +1329,7 @@ bool Widget::newMessageAlert(QWidget* currentWindow, bool isActive, bool sound, bool busySound = Settings::getInstance().getBusySound(); bool notifySound = Settings::getInstance().getNotifySound(); - if (notifySound && sound && (!isBusy || busySound)) - { + if (notifySound && sound && (!isBusy || busySound)) { QString soundPath = Audio::getSound(Audio::Sound::NewMessage); Audio::getInstance().playMono16Sound(soundPath); } @@ -1499,8 +1340,7 @@ bool Widget::newMessageAlert(QWidget* currentWindow, bool isActive, bool sound, void Widget::onFriendRequestReceived(const ToxPk& friendPk, const QString& message) { - if (addFriendForm->addFriendRequest(friendPk.toString(), message)) - { + if (addFriendForm->addFriendRequest(friendPk.toString(), message)) { friendRequestsUpdate(); newMessageAlert(window(), isActiveWindow(), true, true); } @@ -1508,10 +1348,9 @@ void Widget::onFriendRequestReceived(const ToxPk& friendPk, const QString& messa void Widget::updateFriendActivity(Friend* frnd) { - const ToxPk &pk = frnd->getPublicKey(); + const ToxPk& pk = frnd->getPublicKey(); QDate date = Settings::getInstance().getFriendActivity(pk); - if (date != QDate::currentDate()) - { + if (date != QDate::currentDate()) { // Update old activity before after new one. Store old date first. QDate oldDate = Settings::getInstance().getFriendActivity(pk); Settings::getInstance().setFriendActivity(pk, QDate::currentDate()); @@ -1523,26 +1362,22 @@ void Widget::updateFriendActivity(Friend* frnd) void Widget::removeFriend(Friend* f, bool fake) { - if (!fake) - { + if (!fake) { RemoveFriendDialog ask(this, f); ask.exec(); - if (!ask.accepted()) - { - return; + if (!ask.accepted()) { + return; } - if (ask.removeHistory()) - { + if (ask.removeHistory()) { Nexus::getProfile()->getHistory()->removeFriendHistory(f->getPublicKey().toString()); } } - FriendWidget *widget = friendWidgets[f->getFriendId()]; + FriendWidget* widget = friendWidgets[f->getFriendId()]; widget->setAsInactiveChatroom(); - if (widget == activeChatroomWidget) - { + if (widget == activeChatroomWidget) { activeChatroomWidget = nullptr; onAddClicked(); } @@ -1551,8 +1386,7 @@ void Widget::removeFriend(Friend* f, bool fake) ContentDialog* lastDialog = ContentDialog::getFriendDialog(f->getFriendId()); - if (lastDialog != nullptr) - { + if (lastDialog != nullptr) { lastDialog->removeFriend(f->getFriendId()); } @@ -1560,8 +1394,7 @@ void Widget::removeFriend(Friend* f, bool fake) Nexus::getCore()->removeFriend(f->getFriendId(), fake); delete f; - if (contentLayout && contentLayout->mainHead->layout()->isEmpty()) - { + if (contentLayout && contentLayout->mainHead->layout()->isEmpty()) { onAddClicked(); } @@ -1578,14 +1411,12 @@ void Widget::clearContactsList() assert(QThread::currentThread() == qApp->thread()); QList friends = FriendList::getAllFriends(); - for (Friend* f : friends) - { + for (Friend* f : friends) { removeFriend(f, true); } QList groups = GroupList::getAllGroups(); - for (Group* g : groups) - { + for (Group* g : groups) { removeGroup(g, true); } } @@ -1610,13 +1441,11 @@ void Widget::onGroupDialogShown(Group* g) onDialogShown(g->getGroupWidget()); } -void Widget::toggleFullscreen() { - if (windowState().testFlag(Qt::WindowFullScreen)) - { +void Widget::toggleFullscreen() +{ + if (windowState().testFlag(Qt::WindowFullScreen)) { setWindowState(windowState() & ~Qt::WindowFullScreen); - } - else - { + } else { setWindowState(windowState() | Qt::WindowFullScreen); } } @@ -1628,9 +1457,12 @@ ContentDialog* Widget::createContentDialog() const connect(contentDialog, &ContentDialog::groupDialogShown, this, &Widget::onGroupDialogShown); #ifdef Q_OS_MAC - connect(contentDialog, &ContentDialog::destroyed, &Nexus::getInstance(), &Nexus::updateWindowsClosed); - connect(contentDialog, &ContentDialog::windowStateChanged, &Nexus::getInstance(), &Nexus::onWindowStateChanged); - connect(contentDialog->windowHandle(), &QWindow::windowTitleChanged, &Nexus::getInstance(), &Nexus::updateWindows); + connect(contentDialog, &ContentDialog::destroyed, &Nexus::getInstance(), + &Nexus::updateWindowsClosed); + connect(contentDialog, &ContentDialog::windowStateChanged, &Nexus::getInstance(), + &Nexus::onWindowStateChanged); + connect(contentDialog->windowHandle(), &QWindow::windowTitleChanged, &Nexus::getInstance(), + &Nexus::updateWindows); Nexus::getInstance().updateWindows(); #endif return contentDialog; @@ -1661,7 +1493,8 @@ ContentLayout* Widget::createContentDialog(DialogType type) const void retranslateUi() { - setWindowTitle(Core::getInstance()->getUsername() + QStringLiteral(" - ") + Widget::fromDialogType(type)); + setWindowTitle(Core::getInstance()->getUsername() + QStringLiteral(" - ") + + Widget::fromDialogType(type)); setWindowIcon(QIcon(":/img/icons/qtox.svg")); } @@ -1696,8 +1529,10 @@ ContentLayout* Widget::createContentDialog(DialogType type) const #ifdef Q_OS_MAC connect(dialog, &Dialog::destroyed, &Nexus::getInstance(), &Nexus::updateWindowsClosed); - connect(dialog, &ActivateDialog::windowStateChanged, &Nexus::getInstance(), &Nexus::updateWindowsStates); - connect(dialog->windowHandle(), &QWindow::windowTitleChanged, &Nexus::getInstance(), &Nexus::updateWindows); + connect(dialog, &ActivateDialog::windowStateChanged, &Nexus::getInstance(), + &Nexus::updateWindowsStates); + connect(dialog->windowHandle(), &QWindow::windowTitleChanged, &Nexus::getInstance(), + &Nexus::updateWindows); Nexus::getInstance().updateWindows(); #endif @@ -1707,9 +1542,8 @@ ContentLayout* Widget::createContentDialog(DialogType type) const void Widget::copyFriendIdToClipboard(int friendId) { Friend* f = FriendList::findFriend(friendId); - if (f != nullptr) - { - QClipboard *clipboard = QApplication::clipboard(); + if (f != nullptr) { + QClipboard* clipboard = QApplication::clipboard(); const ToxPk& pk = Nexus::getCore()->getFriendPublicKey(f->getFriendId()); clipboard->setText(pk.toString(), QClipboard::Clipboard); } @@ -1719,35 +1553,32 @@ void Widget::onGroupInviteReceived(int32_t friendId, uint8_t type, QByteArray in { updateFriendActivity(FriendList::findFriend(friendId)); - if (type == TOX_CONFERENCE_TYPE_TEXT || type == TOX_CONFERENCE_TYPE_AV) - { + if (type == TOX_CONFERENCE_TYPE_TEXT || type == TOX_CONFERENCE_TYPE_AV) { ++unreadGroupInvites; groupInvitesUpdate(); newMessageAlert(window(), isActiveWindow(), true, true); groupInviteForm->addGroupInvite(friendId, type, invite); - } - else - { - qWarning() << "onGroupInviteReceived: Unknown groupchat type:"<joinGroupchat(friendId, type, (uint8_t*)invite.data(), invite.length()); - if (groupId < 0) - { + int groupId = + Nexus::getCore()->joinGroupchat(friendId, type, (uint8_t*)invite.data(), invite.length()); + if (groupId < 0) { qWarning() << "onGroupInviteAccepted: Unable to accept group invite"; return; } } -void Widget::onGroupMessageReceived(int groupnumber, int peernumber, const QString& message, bool isAction) +void Widget::onGroupMessageReceived(int groupnumber, int peernumber, const QString& message, + bool isAction) { Group* g = GroupList::findGroup(groupnumber); - if (!g) - { + if (!g) { return; } @@ -1755,13 +1586,11 @@ void Widget::onGroupMessageReceived(int groupnumber, int peernumber, const QStri ToxPk author = core->getGroupPeerPk(groupnumber, peernumber); bool isSelf = author == core->getSelfId().getPublicKey(); - bool targeted = !isSelf && (message.contains(nameMention) || message.contains(sanitizedNameMention)); - if (targeted && !isAction) - { + bool targeted = + !isSelf && (message.contains(nameMention) || message.contains(sanitizedNameMention)); + if (targeted && !isAction) { g->getChatForm()->addAlertMessage(author, message, QDateTime::currentDateTime()); - } - else - { + } else { g->getChatForm()->addMessage(author, message, isAction, QDateTime::currentDateTime(), true); } @@ -1771,32 +1600,30 @@ void Widget::onGroupMessageReceived(int groupnumber, int peernumber, const QStri void Widget::onGroupNamelistChanged(int groupnumber, int peernumber, uint8_t Change) { Group* g = GroupList::findGroup(groupnumber); - if (!g) - { - qDebug() << "onGroupNamelistChanged: Group "<(Change); - if (change == TOX_CONFERENCE_STATE_CHANGE_PEER_JOIN) - { + if (change == TOX_CONFERENCE_STATE_CHANGE_PEER_JOIN) { // g->addPeer(peernumber,name); g->regeneratePeerList(); - // g->getChatForm()->addSystemInfoMessage(tr("%1 has joined the chat").arg(name), "white", QDateTime::currentDateTime()); + // g->getChatForm()->addSystemInfoMessage(tr("%1 has joined the chat").arg(name), "white", + // QDateTime::currentDateTime()); // we can't display these messages until toxcore fixes peernumbers // https://github.com/irungentoo/toxcore/issues/1128 - } - else if (change == TOX_CONFERENCE_STATE_CHANGE_PEER_EXIT) - { + } else if (change == TOX_CONFERENCE_STATE_CHANGE_PEER_EXIT) { // g->removePeer(peernumber); g->regeneratePeerList(); - // g->getChatForm()->addSystemInfoMessage(tr("%1 has left the chat").arg(name), "white", QDateTime::currentDateTime()); - } - else if (change == TOX_CONFERENCE_STATE_CHANGE_PEER_NAME_CHANGE) // core overwrites old name before telling us it changed... + // g->getChatForm()->addSystemInfoMessage(tr("%1 has left the chat").arg(name), "white", + // QDateTime::currentDateTime()); + } else if (change == TOX_CONFERENCE_STATE_CHANGE_PEER_NAME_CHANGE) // core overwrites old name + // before telling us it + // changed... { QString name = Nexus::getCore()->getGroupPeerName(groupnumber, peernumber); if (name.isEmpty()) @@ -1809,13 +1636,11 @@ void Widget::onGroupNamelistChanged(int groupnumber, int peernumber, uint8_t Cha void Widget::onGroupTitleChanged(int groupnumber, const QString& author, const QString& title) { Group* g = GroupList::findGroup(groupnumber); - if (!g) - { + if (!g) { return; } - if (!author.isEmpty()) - { + if (!author.isEmpty()) { QString message = tr("%1 has set the title to %2").arg(author, title); QDateTime curTime = QDateTime::currentDateTime(); g->getChatForm()->addSystemInfoMessage(message, ChatMessage::INFO, curTime); @@ -1830,8 +1655,7 @@ void Widget::onGroupTitleChanged(int groupnumber, const QString& author, const Q void Widget::onGroupPeerAudioPlaying(int groupnumber, int peernumber) { Group* g = GroupList::findGroup(groupnumber); - if (!g) - { + if (!g) { return; } @@ -1841,8 +1665,7 @@ void Widget::onGroupPeerAudioPlaying(int groupnumber, int peernumber) void Widget::removeGroup(Group* g, bool fake) { g->getGroupWidget()->setAsInactiveChatroom(); - if (static_cast(g->getGroupWidget()) == activeChatroomWidget) - { + if (static_cast(g->getGroupWidget()) == activeChatroomWidget) { activeChatroomWidget = nullptr; onAddClicked(); } @@ -1852,15 +1675,13 @@ void Widget::removeGroup(Group* g, bool fake) ContentDialog* contentDialog = ContentDialog::getGroupDialog(groupId); - if (contentDialog != nullptr) - { + if (contentDialog != nullptr) { contentDialog->removeGroup(groupId); } Nexus::getCore()->removeGroup(groupId, fake); delete g; - if (contentLayout && contentLayout->mainHead->layout()->isEmpty()) - { + if (contentLayout && contentLayout->mainHead->layout()->isEmpty()) { onAddClicked(); } @@ -1872,19 +1693,17 @@ void Widget::removeGroup(int groupId) removeGroup(GroupList::findGroup(groupId)); } -Group *Widget::createGroup(int groupId) +Group* Widget::createGroup(int groupId) { Group* g = GroupList::findGroup(groupId); - if (g) - { + if (g) { qWarning() << "Group already exists"; return g; } Core* core = Nexus::getCore(); - if (!core) - { + if (!core) { qWarning() << "Can't create group. Core does not exist"; return nullptr; } @@ -1892,8 +1711,7 @@ Group *Widget::createGroup(int groupId) QString groupName = tr("Groupchat #%1").arg(groupId); CoreAV* coreAv = core->getAv(); - if (!coreAv) - { + if (!coreAv) { qWarning() << "Can't create group. CoreAv does not exist"; return nullptr; } @@ -1905,9 +1723,11 @@ Group *Widget::createGroup(int groupId) newgroup->getGroupWidget()->updateStatusLight(); contactListWidget->activateWindow(); - connect(newgroup->getGroupWidget(), SIGNAL(chatroomWidgetClicked(GenericChatroomWidget*,bool)), this, SLOT(onChatroomWidgetClicked(GenericChatroomWidget*,bool))); + connect(newgroup->getGroupWidget(), SIGNAL(chatroomWidgetClicked(GenericChatroomWidget*, bool)), + this, SLOT(onChatroomWidgetClicked(GenericChatroomWidget*, bool))); connect(newgroup->getGroupWidget(), SIGNAL(removeGroup(int)), this, SLOT(removeGroup(int))); - connect(newgroup->getGroupWidget(), SIGNAL(chatroomWidgetClicked(GenericChatroomWidget*)), newgroup->getChatForm(), SLOT(focusInput())); + connect(newgroup->getGroupWidget(), SIGNAL(chatroomWidgetClicked(GenericChatroomWidget*)), + newgroup->getChatForm(), SLOT(focusInput())); connect(newgroup->getChatForm(), &GroupChatForm::sendMessage, core, &Core::sendGroupMessage); connect(newgroup->getChatForm(), &GroupChatForm::sendAction, core, &Core::sendGroupAction); connect(newgroup->getChatForm(), &GroupChatForm::groupTitleChanged, core, &Core::changeGroupTitle); @@ -1921,14 +1741,12 @@ Group *Widget::createGroup(int groupId) void Widget::onEmptyGroupCreated(int groupId) { Group* group = createGroup(groupId); - if (!group) - { + if (!group) { return; } // Only rename group if groups are visible. - if (Widget::getInstance()->groupsVisible()) - { + if (Widget::getInstance()->groupsVisible()) { group->getGroupWidget()->editName(); } } @@ -1936,16 +1754,16 @@ void Widget::onEmptyGroupCreated(int groupId) /** * @brief Used to reset the blinking icon. */ -void Widget::resetIcon() { +void Widget::resetIcon() +{ eventIcon = false; eventFlag = false; updateIcons(); } -bool Widget::event(QEvent * e) +bool Widget::event(QEvent* e) { - switch (e->type()) - { + switch (e->type()) { case QEvent::MouseButtonPress: case QEvent::MouseButtonDblClick: focusChatInput(); @@ -1954,15 +1772,13 @@ bool Widget::event(QEvent * e) ui->friendList->updateVisualTracking(); break; case QEvent::WindowActivate: - if (activeChatroomWidget) - { + if (activeChatroomWidget) { activeChatroomWidget->resetEventFlags(); activeChatroomWidget->updateStatusLight(); setWindowTitle(activeChatroomWidget->getTitle()); } - if (eventFlag) - { + if (eventFlag) { resetIcon(); } @@ -1987,26 +1803,19 @@ void Widget::onUserAwayCheck() #ifdef QTOX_PLATFORM_EXT uint32_t autoAwayTime = Settings::getInstance().getAutoAwayTime() * 60 * 1000; - if (ui->statusButton->property("status").toString() == "online") - { - if (autoAwayTime && Platform::getIdleTime() >= autoAwayTime) - { + if (ui->statusButton->property("status").toString() == "online") { + if (autoAwayTime && Platform::getIdleTime() >= autoAwayTime) { qDebug() << "auto away activated at" << QTime::currentTime().toString(); emit statusSet(Status::Away); autoAwayActive = true; } - } - else if (ui->statusButton->property("status").toString() == "away") - { - if (autoAwayActive && (!autoAwayTime || Platform::getIdleTime() < autoAwayTime)) - { + } else if (ui->statusButton->property("status").toString() == "away") { + if (autoAwayActive && (!autoAwayTime || Platform::getIdleTime() < autoAwayTime)) { qDebug() << "auto away deactivated at" << QTime::currentTime().toString(); emit statusSet(Status::Online); autoAwayActive = false; } - } - else if (autoAwayActive) - { + } else if (autoAwayActive) { autoAwayActive = false; } #endif @@ -2014,8 +1823,7 @@ void Widget::onUserAwayCheck() void Widget::onEventIconTick() { - if (eventFlag) - { + if (eventFlag) { eventIcon ^= true; updateIcons(); } @@ -2024,10 +1832,8 @@ void Widget::onEventIconTick() void Widget::onTryCreateTrayIcon() { static int32_t tries = 15; - if (!icon && tries--) - { - if (QSystemTrayIcon::isSystemTrayAvailable()) - { + if (!icon && tries--) { + if (QSystemTrayIcon::isSystemTrayAvailable()) { icon = new SystemTrayIcon(); updateIcons(); trayMenu = new QMenu(this); @@ -2047,30 +1853,22 @@ void Widget::onTryCreateTrayIcon() if (icon->backend() != SystrayBackendType::Unity) connect(icon, &SystemTrayIcon::activated, this, &Widget::onIconClick); - if (Settings::getInstance().getShowSystemTray()) - { + if (Settings::getInstance().getShowSystemTray()) { icon->show(); setHidden(Settings::getInstance().getAutostartInTray()); - } - else - { + } else { show(); } #ifdef Q_OS_MAC qt_mac_set_dock_menu(Nexus::getInstance().dockMenu); #endif - } - else if (!isVisible()) - { + } else if (!isVisible()) { show(); } - } - else - { + } else { disconnect(timer, &QTimer::timeout, this, &Widget::onTryCreateTrayIcon); - if (!icon) - { + if (!icon) { qWarning() << "No system tray detected!"; show(); } @@ -2079,8 +1877,7 @@ void Widget::onTryCreateTrayIcon() void Widget::setStatusOnline() { - if (!ui->statusButton->isEnabled()) - { + if (!ui->statusButton->isEnabled()) { return; } @@ -2089,8 +1886,7 @@ void Widget::setStatusOnline() void Widget::setStatusAway() { - if (!ui->statusButton->isEnabled()) - { + if (!ui->statusButton->isEnabled()) { return; } @@ -2099,8 +1895,7 @@ void Widget::setStatusAway() void Widget::setStatusBusy() { - if (!ui->statusButton->isEnabled()) - { + if (!ui->statusButton->isEnabled()) { return; } @@ -2112,8 +1907,7 @@ void Widget::onMessageSendResult(uint32_t friendId, const QString& message, int Q_UNUSED(message) Q_UNUSED(messageId) Friend* f = FriendList::findFriend(friendId); - if (!f) - { + if (!f) { return; } } @@ -2122,13 +1916,11 @@ void Widget::onGroupSendResult(int groupId, const QString& message, int result) { Q_UNUSED(message) Group* g = GroupList::findGroup(groupId); - if (!g) - { + if (!g) { return; } - if (result == -1) - { + if (result == -1) { QString message = tr("Message failed to send"); QDateTime curTime = QDateTime::currentDateTime(); g->getChatForm()->addSystemInfoMessage(message, ChatMessage::INFO, curTime); @@ -2138,8 +1930,7 @@ void Widget::onGroupSendResult(int groupId, const QString& message, int result) void Widget::onFriendTypingChanged(int friendId, bool isTyping) { Friend* f = FriendList::findFriend(friendId); - if (!f) - { + if (!f) { return; } @@ -2148,8 +1939,7 @@ void Widget::onFriendTypingChanged(int friendId, bool isTyping) void Widget::onSetShowSystemTray(bool newValue) { - if (icon) - { + if (icon) { icon->setVisible(newValue); } } @@ -2179,47 +1969,42 @@ void Widget::cycleContacts(bool forward) bool Widget::filterGroups(FilterCriteria index) { - switch (index) - { - case FilterCriteria::Offline: - case FilterCriteria::Friends: - return true; - default: - return false; + switch (index) { + case FilterCriteria::Offline: + case FilterCriteria::Friends: + return true; + default: + return false; } } bool Widget::filterOffline(FilterCriteria index) { - switch (index) - { - case FilterCriteria::Online: - case FilterCriteria::Groups: - return true; - default: - return false; + switch (index) { + case FilterCriteria::Online: + case FilterCriteria::Groups: + return true; + default: + return false; } } bool Widget::filterOnline(FilterCriteria index) { - switch (index) - { - case FilterCriteria::Offline: - case FilterCriteria::Groups: - return true; - default: - return false; + switch (index) { + case FilterCriteria::Offline: + case FilterCriteria::Groups: + return true; + default: + return false; } } void Widget::processOfflineMsgs() { - if (OfflineMsgEngine::globalMutex.tryLock()) - { + if (OfflineMsgEngine::globalMutex.tryLock()) { QList frnds = FriendList::getAllFriends(); - for (Friend* f : frnds) - { + for (Friend* f : frnds) { f->getChatForm()->getOfflineMsgEngine()->deliverOfflineMsgs(); } @@ -2230,8 +2015,7 @@ void Widget::processOfflineMsgs() void Widget::clearAllReceipts() { QList frnds = FriendList::getAllFriends(); - for (Friend* f : frnds) - { + for (Friend* f : frnds) { f->getChatForm()->getOfflineMsgEngine()->removeAllReceipts(); } } @@ -2246,14 +2030,12 @@ void Widget::reloadTheme() ui->statusButton->setStyleSheet(Style::getStylesheet(":/ui/statusButton/statusButton.css")); contactListWidget->reDraw(); - for (Friend* f : FriendList::getAllFriends()) - { + for (Friend* f : FriendList::getAllFriends()) { int friendId = f->getFriendId(); friendWidgets[friendId]->reloadTheme(); } - for (Group* g : GroupList::getAllGroups()) - { + for (Group* g : GroupList::getAllGroups()) { g->getGroupWidget()->reloadTheme(); } } @@ -2270,8 +2052,7 @@ void Widget::previousContact() QString Widget::getStatusIconPath(Status status) { - switch (status) - { + switch (status) { case Status::Online: return ":/img/status/dot_online.svg"; case Status::Away: @@ -2292,8 +2073,7 @@ QPixmap Widget::getStatusIconPixmap(QString path, uint32_t w, uint32_t h) QString Widget::getStatusTitle(Status status) { - switch (status) - { + switch (status) { case Status::Online: return QStringLiteral("online"); case Status::Away: @@ -2325,9 +2105,7 @@ void Widget::searchContacts() QString searchString = ui->searchContactText->text(); FilterCriteria filter = getFilterCriteria(); - contactListWidget->searchChatrooms(searchString, - filterOnline(filter), - filterOffline(filter), + contactListWidget->searchChatrooms(searchString, filterOnline(filter), filterOffline(filter), filterGroups(filter)); updateFilterText(); @@ -2339,12 +2117,9 @@ void Widget::changeDisplayMode() { filterDisplayGroup->setEnabled(false); - if (filterDisplayGroup->checkedAction() == filterDisplayActivity) - { + if (filterDisplayGroup->checkedAction() == filterDisplayActivity) { contactListWidget->setMode(FriendListWidget::Activity); - } - else if (filterDisplayGroup->checkedAction() == filterDisplayName) - { + } else if (filterDisplayGroup->checkedAction() == filterDisplayName) { contactListWidget->setMode(FriendListWidget::Name); } @@ -2378,24 +2153,23 @@ Widget::FilterCriteria Widget::getFilterCriteria() const return FilterCriteria::All; } -void Widget::searchCircle(CircleWidget *circleWidget) +void Widget::searchCircle(CircleWidget* circleWidget) { FilterCriteria filter = getFilterCriteria(); QString text = ui->searchContactText->text(); circleWidget->search(text, true, filterOnline(filter), filterOffline(filter)); } -void Widget::searchItem(GenericChatItemWidget *chatItem, GenericChatItemWidget::ItemType type) +void Widget::searchItem(GenericChatItemWidget* chatItem, GenericChatItemWidget::ItemType type) { bool hide; FilterCriteria filter = getFilterCriteria(); - switch (type) - { - case GenericChatItemWidget::GroupItem: - hide = filterGroups(filter); - break; - default: - hide = true; + switch (type) { + case GenericChatItemWidget::GroupItem: + hide = filterGroups(filter); + break; + default: + hide = true; } chatItem->searchName(ui->searchContactText->text(), hide); @@ -2407,19 +2181,16 @@ bool Widget::groupsVisible() const return !filterGroups(filter); } -void Widget::friendListContextMenu(const QPoint &pos) +void Widget::friendListContextMenu(const QPoint& pos) { QMenu menu(this); - QAction *createGroupAction = menu.addAction(tr("Create new group...")); - QAction *addCircleAction = menu.addAction(tr("Add new circle...")); - QAction *chosenAction = menu.exec(ui->friendList->mapToGlobal(pos)); + QAction* createGroupAction = menu.addAction(tr("Create new group...")); + QAction* addCircleAction = menu.addAction(tr("Add new circle...")); + QAction* chosenAction = menu.exec(ui->friendList->mapToGlobal(pos)); - if (chosenAction == addCircleAction) - { + if (chosenAction == addCircleAction) { contactListWidget->addCircleWidget(); - } - else if (chosenAction == createGroupAction) - { + } else if (chosenAction == createGroupAction) { Nexus::getCore()->createGroup(); } } @@ -2428,49 +2199,39 @@ void Widget::friendRequestsUpdate() { unsigned int unreadFriendRequests = Settings::getInstance().getUnreadFriendRequests(); - if (unreadFriendRequests == 0) - { + if (unreadFriendRequests == 0) { delete friendRequestsButton; friendRequestsButton = nullptr; - } - else if (!friendRequestsButton) - { + } else if (!friendRequestsButton) { friendRequestsButton = new QPushButton(this); friendRequestsButton->setObjectName("green"); ui->statusLayout->insertWidget(2, friendRequestsButton); - connect(friendRequestsButton, &QPushButton::released, [this]() - { + connect(friendRequestsButton, &QPushButton::released, [this]() { onAddClicked(); addFriendForm->setMode(AddFriendForm::Mode::FriendRequest); }); } - if (friendRequestsButton) - { + if (friendRequestsButton) { friendRequestsButton->setText(tr("%n New Friend Request(s)", "", unreadFriendRequests)); } } void Widget::groupInvitesUpdate() { - if (unreadGroupInvites == 0) - { + if (unreadGroupInvites == 0) { delete groupInvitesButton; groupInvitesButton = nullptr; - } - else if (!groupInvitesButton) - { + } else if (!groupInvitesButton) { groupInvitesButton = new QPushButton(this); groupInvitesButton->setObjectName("green"); ui->statusLayout->insertWidget(2, groupInvitesButton); - connect(groupInvitesButton, &QPushButton::released, - this, &Widget::onGroupClicked); + connect(groupInvitesButton, &QPushButton::released, this, &Widget::onGroupClicked); } - if (groupInvitesButton) - { + if (groupInvitesButton) { groupInvitesButton->setText(tr("%n New Group Invite(s)", "", unreadGroupInvites)); } } @@ -2544,14 +2305,10 @@ void Widget::retranslateUi() void Widget::focusChatInput() { - if (activeChatroomWidget) - { - if (Friend* f = activeChatroomWidget->getFriend()) - { + if (activeChatroomWidget) { + if (Friend* f = activeChatroomWidget->getFriend()) { f->getChatForm()->focusInput(); - } - else if (Group* g = activeChatroomWidget->getGroup()) - { + } else if (Group* g = activeChatroomWidget->getGroup()) { g->getChatForm()->focusInput(); } } diff --git a/src/widget/widget.h b/src/widget/widget.h index eaa11bd00..d08d1e13a 100644 --- a/src/widget/widget.h +++ b/src/widget/widget.h @@ -22,10 +22,10 @@ #include "ui_mainwindow.h" +#include #include #include #include -#include #include "genericchatitemwidget.h" @@ -98,14 +98,14 @@ public: explicit Widget(QWidget* parent = 0); ~Widget(); void init(); - void setCentralWidget(QWidget* widget, const QString &widgetName); + void setCentralWidget(QWidget* widget, const QString& widgetName); QString getUsername(); Camera* getCamera(); static Widget* getInstance(); void showUpdateDownloadProgress(); void addFriendDialog(Friend* frnd, ContentDialog* dialog); void addGroupDialog(Group* group, ContentDialog* dialog); - bool newFriendMessageAlert(int friendId, bool sound=true); + bool newFriendMessageAlert(int friendId, bool sound = true); bool newGroupMessageAlert(int groupId, bool notify); bool getIsWindowMinimized(); void updateIcons(); @@ -115,7 +115,7 @@ public: ContentDialog* createContentDialog() const; ContentLayout* createContentDialog(DialogType type) const; - static void confirmExecutableOpen(const QFileInfo &file); + static void confirmExecutableOpen(const QFileInfo& file); void clearAllReceipts(); void reloadHistory(); @@ -145,7 +145,7 @@ public slots: void onBadProxyCore(); void onSelfAvatarLoaded(const QPixmap& pic); void setUsername(const QString& username); - void setStatusMessage(const QString &statusMessage); + void setStatusMessage(const QString& statusMessage); void addFriend(int friendId, const ToxPk& friendPk); void addFriendFailed(const ToxPk& userId, const QString& errorInfo = QString()); void onFriendshipChanged(int friendId); @@ -184,12 +184,12 @@ signals: void windowStateChanged(Qt::WindowStates states); protected: - virtual bool eventFilter(QObject *obj, QEvent *event) final override; - virtual bool event(QEvent * e) final override; - virtual void closeEvent(QCloseEvent *event) final override; - virtual void changeEvent(QEvent *event) final override; - virtual void resizeEvent(QResizeEvent *event) final override; - virtual void moveEvent(QMoveEvent *event) final override; + virtual bool eventFilter(QObject* obj, QEvent* event) final override; + virtual bool event(QEvent* e) final override; + virtual void closeEvent(QCloseEvent* event) final override; + virtual void changeEvent(QEvent* event) final override; + virtual void resizeEvent(QResizeEvent* event) final override; + virtual void moveEvent(QMoveEvent* event) final override; private slots: void onAddClicked(); @@ -211,7 +211,7 @@ private slots: void onSetShowSystemTray(bool newValue); void onSplitterMoved(int pos, int index); void processOfflineMsgs(); - void friendListContextMenu(const QPoint &pos); + void friendListContextMenu(const QPoint& pos); void friendRequestsUpdate(); void groupInvitesUpdate(); void groupInvitesClear(); @@ -241,14 +241,14 @@ private: void focusChatInput(); private: - SystemTrayIcon *icon = nullptr; - QMenu *trayMenu; - QAction *statusOnline; - QAction *statusAway; - QAction *statusBusy; - QAction *actionLogout; - QAction *actionQuit; - QAction *actionShow; + SystemTrayIcon* icon = nullptr; + QMenu* trayMenu; + QAction* statusOnline; + QAction* statusAway; + QAction* statusBusy; + QAction* actionLogout; + QAction* actionQuit; + QAction* actionShow; QMenu* filterMenu; @@ -263,20 +263,20 @@ private: QAction* filterDisplayName; QAction* filterDisplayActivity; - Ui::MainWindow *ui; - QSplitter *centralLayout; + Ui::MainWindow* ui; + QSplitter* centralLayout; QPoint dragPosition; ContentLayout* contentLayout; - AddFriendForm *addFriendForm; + AddFriendForm* addFriendForm; GroupInviteForm* groupInviteForm; - ProfileForm *profileForm; + ProfileForm* profileForm; QPointer settingsWidget; - FilesForm *filesForm; - static Widget *instance; - GenericChatroomWidget *activeChatroomWidget; - FriendListWidget *contactListWidget; - MaskablePixmapWidget *profilePicture; - bool notify(QObject *receiver, QEvent *event); + FilesForm* filesForm; + static Widget* instance; + GenericChatroomWidget* activeChatroomWidget; + FriendListWidget* contactListWidget; + MaskablePixmapWidget* profilePicture; + bool notify(QObject* receiver, QEvent* event); bool autoAwayActive = false; QTimer *timer, *offlineMsgTimer; QRegExp nameMention, sanitizedNameMention; diff --git a/test/chatlog/textformatter_test.cpp b/test/chatlog/textformatter_test.cpp index 5918acebd..e05c355cd 100644 --- a/test/chatlog/textformatter_test.cpp +++ b/test/chatlog/textformatter_test.cpp @@ -20,76 +20,59 @@ #include "src/chatlog/textformatter.h" #include "test/common.h" +#include +#include #include #include #include -#include -#include #include using StringToString = QMap; -static const StringToString signsToTags -{ - { "*", "b" }, - { "**", "b" }, - { "/", "i" } -}; +static const StringToString signsToTags{{"*", "b"}, {"**", "b"}, {"/", "i"}}; -static const StringToString commonWorkCases -{ - // Basic - { QStringLiteral("%1a%1"), QStringLiteral("<%2>%1a%1") }, - { QStringLiteral("%1aa%1"), QStringLiteral("<%2>%1aa%1") }, - { QStringLiteral("%1aaa%1"), QStringLiteral("<%2>%1aaa%1") }, +static const StringToString + commonWorkCases{// Basic + {QStringLiteral("%1a%1"), QStringLiteral("<%2>%1a%1")}, + {QStringLiteral("%1aa%1"), QStringLiteral("<%2>%1aa%1")}, + {QStringLiteral("%1aaa%1"), QStringLiteral("<%2>%1aaa%1")}, - // Additional text from both sides - { QStringLiteral("aaa%1a%1"), QStringLiteral("aaa<%2>%1a%1") }, - { QStringLiteral("%1a%1aaa"), QStringLiteral("<%2>%1a%1aaa") }, + // Additional text from both sides + {QStringLiteral("aaa%1a%1"), QStringLiteral("aaa<%2>%1a%1")}, + {QStringLiteral("%1a%1aaa"), QStringLiteral("<%2>%1a%1aaa")}, - // Must allow same formatting more than one time, divided by two and more symbols due to QRegularExpressionIterator - { QStringLiteral("%1aaa%1 aaa %1aaa%1"), QStringLiteral("<%2>%1aaa%1 aaa <%2>%1aaa%1") } -}; + // Must allow same formatting more than one time, divided by two and more + // symbols due to QRegularExpressionIterator + {QStringLiteral("%1aaa%1 aaa %1aaa%1"), + QStringLiteral("<%2>%1aaa%1 aaa <%2>%1aaa%1")}}; -static const QVector commonExceptions -{ - // No whitespaces near to formatting symbols from both sides - QStringLiteral("%1 a%1"), - QStringLiteral("%1a %1"), +static const QVector + commonExceptions{// No whitespaces near to formatting symbols from both sides + QStringLiteral("%1 a%1"), QStringLiteral("%1a %1"), - // No newlines - QStringLiteral("%1aa\n%1"), + // No newlines + QStringLiteral("%1aa\n%1"), - // Only exact combinations of symbols must encapsulate formatting string - QStringLiteral("%1%1aaa%1"), - QStringLiteral("%1aaa%1%1") -}; + // Only exact combinations of symbols must encapsulate formatting string + QStringLiteral("%1%1aaa%1"), QStringLiteral("%1aaa%1%1")}; -static const StringToString singleSlash -{ +static const StringToString singleSlash{ // Must work with inserted tags - { QStringLiteral("/aaaaaa aaa/"), QStringLiteral("aaaaaa aaa") } -}; + {QStringLiteral("/aaaaaa aaa/"), QStringLiteral("aaaaaa aaa")}}; -static const StringToString doubleSign -{ - { QStringLiteral("**aaa * aaa**"), QStringLiteral("aaa * aaa") } -}; +static const StringToString doubleSign{ + {QStringLiteral("**aaa * aaa**"), QStringLiteral("aaa * aaa")}}; -static const StringToString mixedFormatting -{ +static const StringToString mixedFormatting{ // Must allow mixed formatting if there is no tag overlap in result - { QStringLiteral("aaa *aaa /aaa/ aaa*"), QStringLiteral("aaa aaa aaa aaa") }, - { QStringLiteral("aaa *aaa /aaa* aaa/"), QStringLiteral("aaa aaa /aaa aaa/") } -}; + {QStringLiteral("aaa *aaa /aaa/ aaa*"), QStringLiteral("aaa aaa aaa aaa")}, + {QStringLiteral("aaa *aaa /aaa* aaa/"), QStringLiteral("aaa aaa /aaa aaa/")}}; -static const StringToString multilineCode -{ +static const StringToString multilineCode{ // Must allow newlines - { QStringLiteral("```int main()\n{\n return 0;\n}```"), - QStringLiteral("int main()\n{\n return 0;\n}") } -}; + {QStringLiteral("```int main()\n{\n return 0;\n}```"), + QStringLiteral("int main()\n{\n return 0;\n}")}}; /** * @brief Testing cases which are common for all types of formatting except multiline code @@ -99,8 +82,7 @@ static const StringToString multilineCode */ static void commonTest(bool showSymbols, const StringToString map, const QString signs) { - for (QString key : map.keys()) - { + for (QString key : map.keys()) { QString source = key.arg(signs); TextFormatter tf = TextFormatter(source); QString result = map[key].arg(showSymbols ? signs : "", signsToTags[signs]); @@ -114,8 +96,7 @@ static void commonTest(bool showSymbols, const StringToString map, const QString */ static void commonExceptionsTest(const QString signs) { - for (QString source : commonExceptions) - { + for (QString source : commonExceptions) { TextFormatter tf = TextFormatter(source.arg(signs)); ck_assert(tf.applyStyling(false) == source.arg(signs)); } @@ -127,8 +108,7 @@ static void commonExceptionsTest(const QString signs) */ static void specialTest(const StringToString map) { - for (QString key : map.keys()) - { + for (QString key : map.keys()) { TextFormatter tf = TextFormatter(key); ck_assert(tf.applyStyling(false) == map[key]); } @@ -233,9 +213,9 @@ static Suite* textFormatterSuite(void) return s; } -int main(int argc, char *argv[]) +int main(int argc, char* argv[]) { - srand((unsigned int) time(NULL)); + srand((unsigned int)time(NULL)); Suite* tf = textFormatterSuite(); SRunner* runner = srunner_create(tf); diff --git a/test/common.h b/test/common.h index 1fc564dca..effb27d56 100644 --- a/test/common.h +++ b/test/common.h @@ -2,12 +2,12 @@ #define _TEST_COMMON_H_ #define DEFTESTCASE(NAME) \ - TCase *tc_##NAME = tcase_create(#NAME); \ - tcase_add_test(tc_##NAME, NAME##Test); \ + TCase* tc_##NAME = tcase_create(#NAME); \ + tcase_add_test(tc_##NAME, NAME##Test); \ suite_add_tcase(s, tc_##NAME); #define DEFTESTCASE_SLOW(NAME, TIMEOUT) \ - DEFTESTCASE(NAME) \ + DEFTESTCASE(NAME) \ tcase_set_timeout(tc_##NAME, TIMEOUT); #endif // _TEST_COMMON_H_ diff --git a/test/core/toxid_test.cpp b/test/core/toxid_test.cpp index 110b05a02..763919fed 100644 --- a/test/core/toxid_test.cpp +++ b/test/core/toxid_test.cpp @@ -24,10 +24,14 @@ #include #include -const QString corrupted = QStringLiteral("C7719C6808C14B77348004956D1D98046CE09A34370E7608150EAD74C3815D30C8BA3AB9BEBA"); -const QString testToxId = QStringLiteral("C7719C6808C14B77348004956D1D98046CE09A34370E7608150EAD74C3815D30C8BA3AB9BEB9"); -const QString publicKey = QStringLiteral("C7719C6808C14B77348004956D1D98046CE09A34370E7608150EAD74C3815D30"); -const QString echoToxId = QStringLiteral("76518406F6A9F2217E8DC487CC783C25CC16A15EB36FF32E335A235342C48A39218F515C39A6"); +const QString corrupted = + QStringLiteral("C7719C6808C14B77348004956D1D98046CE09A34370E7608150EAD74C3815D30C8BA3AB9BEBA"); +const QString testToxId = + QStringLiteral("C7719C6808C14B77348004956D1D98046CE09A34370E7608150EAD74C3815D30C8BA3AB9BEB9"); +const QString publicKey = + QStringLiteral("C7719C6808C14B77348004956D1D98046CE09A34370E7608150EAD74C3815D30"); +const QString echoToxId = + QStringLiteral("76518406F6A9F2217E8DC487CC783C25CC16A15EB36FF32E335A235342C48A39218F515C39A6"); START_TEST(toStringTest) { @@ -81,9 +85,9 @@ START_TEST(validationTest) } END_TEST -static Suite *toxIdSuite(void) +static Suite* toxIdSuite(void) { - Suite *s = suite_create("ToxId"); + Suite* s = suite_create("ToxId"); DEFTESTCASE(toString); DEFTESTCASE(equal); @@ -95,12 +99,12 @@ static Suite *toxIdSuite(void) return s; } -int main(int argc, char *argv[]) +int main(int argc, char* argv[]) { - srand((unsigned int) time(NULL)); + srand((unsigned int)time(NULL)); - Suite *toxId = toxIdSuite(); - SRunner *runner = srunner_create(toxId); + Suite* toxId = toxIdSuite(); + SRunner* runner = srunner_create(toxId); srunner_run_all(runner, CK_NORMAL); int res = srunner_ntests_failed(runner); diff --git a/test/core/toxpk_test.cpp b/test/core/toxpk_test.cpp index 99c90f03a..a7e272756 100644 --- a/test/core/toxpk_test.cpp +++ b/test/core/toxpk_test.cpp @@ -21,21 +21,21 @@ #include "test/common.h" -#include #include +#include #include -const uint8_t testPkArray[32] = { - 0xC7, 0x71, 0x9C, 0x68, 0x08, 0xC1, 0x4B, 0x77, 0x34, 0x80, 0x04, - 0x95, 0x6D, 0x1D, 0x98, 0x04, 0x6C, 0xE0, 0x9A, 0x34, 0x37, 0x0E, - 0x76, 0x08, 0x15, 0x0E, 0xAD, 0x74, 0xC3, 0x81, 0x5D, 0x30 -}; +const uint8_t testPkArray[32] = {0xC7, 0x71, 0x9C, 0x68, 0x08, 0xC1, 0x4B, 0x77, 0x34, 0x80, 0x04, + 0x95, 0x6D, 0x1D, 0x98, 0x04, 0x6C, 0xE0, 0x9A, 0x34, 0x37, 0x0E, + 0x76, 0x08, 0x15, 0x0E, 0xAD, 0x74, 0xC3, 0x81, 0x5D, 0x30}; -const QString testStr = QStringLiteral("C7719C6808C14B77348004956D1D98046CE09A34370E7608150EAD74C3815D30"); +const QString testStr = + QStringLiteral("C7719C6808C14B77348004956D1D98046CE09A34370E7608150EAD74C3815D30"); const QByteArray testPk = QByteArray::fromHex(testStr.toLatin1()); -const QString echoStr = QStringLiteral("76518406F6A9F2217E8DC487CC783C25CC16A15EB36FF32E335A235342C48A39"); +const QString echoStr = + QStringLiteral("76518406F6A9F2217E8DC487CC783C25CC16A15EB36FF32E335A235342C48A39"); const QByteArray echoPk = QByteArray::fromHex(echoStr.toLatin1()); START_TEST(toStringTest) @@ -83,25 +83,25 @@ START_TEST(publicKeyTest) } END_TEST -static Suite *toxPkSuite(void) +static Suite* toxPkSuite(void) { - Suite *s = suite_create("ToxPk"); + Suite* s = suite_create("ToxPk"); DEFTESTCASE(toString); DEFTESTCASE(equal); DEFTESTCASE(clear); DEFTESTCASE(publicKey); DEFTESTCASE(copy); - + return s; } -int main(int argc, char *argv[]) +int main(int argc, char* argv[]) { - srand((unsigned int) time(NULL)); + srand((unsigned int)time(NULL)); - Suite *toxPk = toxPkSuite(); - SRunner *runner = srunner_create(toxPk); + Suite* toxPk = toxPkSuite(); + SRunner* runner = srunner_create(toxPk); srunner_run_all(runner, CK_NORMAL); int res = srunner_ntests_failed(runner); diff --git a/test/core/utils.h b/test/core/utils.h index f18d1192d..836aa69f9 100644 --- a/test/core/utils.h +++ b/test/core/utils.h @@ -1,13 +1,13 @@ #ifndef _TEST_UTILS_H_ -#define _TEST_UTILS_H_ +#define _TEST_UTILS_H_ #define DEFTESTCASE(NAME) \ - TCase *tc_##NAME = tcase_create(#NAME); \ - tcase_add_test(tc_##NAME, NAME##Test); \ + TCase* tc_##NAME = tcase_create(#NAME); \ + tcase_add_test(tc_##NAME, NAME##Test); \ suite_add_tcase(s, tc_##NAME); #define DEFTESTCASE_SLOW(NAME, TIMEOUT) \ - DEFTESTCASE(NAME) \ + DEFTESTCASE(NAME) \ tcase_set_timeout(tc_##NAME, TIMEOUT); #endif // _TEST_UTILS_H_ diff --git a/updater/main.cpp b/updater/main.cpp index 9a226e915..9512a5055 100644 --- a/updater/main.cpp +++ b/updater/main.cpp @@ -18,47 +18,48 @@ */ -#include "widget.h" #include "settings.h" +#include "widget.h" #include +#include #include +#include #include #include -#include -#include #include #include #include -static std::unique_ptr logFileStream {nullptr}; -static std::unique_ptr logFileFile {nullptr}; +static std::unique_ptr logFileStream{nullptr}; +static std::unique_ptr logFileFile{nullptr}; static QMutex mutex; void logMessageHandler(QtMsgType type, const QMessageLogContext& ctxt, const QString& msg) { // Silence qWarning spam due to bug in QTextBrowser (trying to open a file for base64 images) if (ctxt.function == QString("virtual bool QFSFileEngine::open(QIODevice::OpenMode)") - && msg == QString("QFSFileEngine::open: No file name specified")) + && msg == QString("QFSFileEngine::open: No file name specified")) return; QString LogMsg = QString("[%1] %2:%3 : ") - .arg(QTime::currentTime().toString("HH:mm:ss.zzz")).arg(ctxt.file).arg(ctxt.line); - switch (type) - { - case QtDebugMsg: - LogMsg += "Debug"; - break; - case QtWarningMsg: - LogMsg += "Warning"; - break; - case QtCriticalMsg: - LogMsg += "Critical"; - break; - case QtFatalMsg: - LogMsg += "Fatal"; - break; - default: - break; + .arg(QTime::currentTime().toString("HH:mm:ss.zzz")) + .arg(ctxt.file) + .arg(ctxt.line); + switch (type) { + case QtDebugMsg: + LogMsg += "Debug"; + break; + case QtWarningMsg: + LogMsg += "Warning"; + break; + case QtCriticalMsg: + LogMsg += "Critical"; + break; + case QtFatalMsg: + LogMsg += "Fatal"; + break; + default: + break; } LogMsg += ": " + msg + "\n"; @@ -74,26 +75,24 @@ void logMessageHandler(QtMsgType type, const QMessageLogContext& ctxt, const QSt logFileStream->flush(); } -int main(int argc, char *argv[]) +int main(int argc, char* argv[]) { qInstallMessageHandler(logMessageHandler); QApplication a(argc, argv); Settings s; logFileStream.reset(new QTextStream); - logFileFile.reset(new QFile(s.getSettingsDirPath()+"qtox.log")); - if (logFileFile->open(QIODevice::Append)) - { + logFileFile.reset(new QFile(s.getSettingsDirPath() + "qtox.log")); + if (logFileFile->open(QIODevice::Append)) { logFileStream->setDevice(logFileFile.get()); - *logFileStream << QDateTime::currentDateTime().toString("\nyyyy-MM-dd HH:mm:ss' Updater file logger starting\n'"); - } - else - { + *logFileStream << QDateTime::currentDateTime().toString( + "\nyyyy-MM-dd HH:mm:ss' Updater file logger starting\n'"); + } else { qWarning() << "Couldn't open log file!\n"; logFileStream.release(); } - long unsigned int bufsize=100; + long unsigned int bufsize = 100; char buf[100]; GetUserNameA(buf, &bufsize); qDebug() << "Updater running as user" << buf; diff --git a/updater/serialize.cpp b/updater/serialize.cpp index 8a891fff8..7e70d1656 100644 --- a/updater/serialize.cpp +++ b/updater/serialize.cpp @@ -27,11 +27,11 @@ QByteArray doubleToData(double num) char tab[8]; double n; } castUnion; - //char n[8]; + // char n[8]; //*((double*) n) = num; - castUnion.n=num; - return QByteArray(castUnion.tab,8); + castUnion.n = num; + return QByteArray(castUnion.tab, 8); } QByteArray floatToData(float num) @@ -42,8 +42,8 @@ QByteArray floatToData(float num) float n; } castUnion; - castUnion.n=num; - return QByteArray(castUnion.tab,4); + castUnion.n = num; + return QByteArray(castUnion.tab, 4); } float dataToFloat(QByteArray data) @@ -54,28 +54,28 @@ float dataToFloat(QByteArray data) float n; } castUnion; - castUnion.tab[0]=data.data()[0]; - castUnion.tab[1]=data.data()[1]; - castUnion.tab[2]=data.data()[2]; - castUnion.tab[3]=data.data()[3]; + castUnion.tab[0] = data.data()[0]; + castUnion.tab[1] = data.data()[1]; + castUnion.tab[2] = data.data()[2]; + castUnion.tab[3] = data.data()[3]; return castUnion.n; } // Converts a string into PNet string data QByteArray stringToData(QString str) { - QByteArray data(4,0); + QByteArray data(4, 0); // Write the size in a Uint of variable lenght (8-32 bits) - int i=0; + int i = 0; uint num1 = (uint)str.toUtf8().size(); - while (num1 >= 0x80) - { - data[i] = (unsigned char)(num1 | 0x80); i++; + while (num1 >= 0x80) { + data[i] = (unsigned char)(num1 | 0x80); + i++; num1 = num1 >> 7; } - data[i]=num1; - data.resize(i+1); - data+=str.toUtf8(); + data[i] = num1; + data.resize(i + 1); + data += str.toUtf8(); return data; } @@ -85,58 +85,55 @@ QString dataToString(QByteArray data) unsigned char num3; int num = 0; int num2 = 0; - int i=0; - do - { - num3 = data[i]; i++; + int i = 0; + do { + num3 = data[i]; + i++; num |= (num3 & 0x7f) << num2; num2 += 7; } while ((num3 & 0x80) != 0); - unsigned int strlen = (uint) num; + unsigned int strlen = (uint)num; if (!strlen) return QString(); - data = data.right(data.size()-i); // Remove the strlen + data = data.right(data.size() - i); // Remove the strlen data.truncate(strlen); return QString(data); } float dataToRangedSingle(float min, float max, int numberOfBits, QByteArray data) { - uint endvalue=0; - uint value=0; - if (numberOfBits <= 8) - { + uint endvalue = 0; + uint value = 0; + if (numberOfBits <= 8) { endvalue = (uchar)data[0]; goto done; } value = (uchar)data[0]; numberOfBits -= 8; - if (numberOfBits <= 8) - { - endvalue = (value | ((uint) ((uchar)data[1]) << 8)); + if (numberOfBits <= 8) { + endvalue = (value | ((uint)((uchar)data[1]) << 8)); goto done; } - value |= (uint) (((uchar)data[1]) << 8); + value |= (uint)(((uchar)data[1]) << 8); numberOfBits -= 8; - if (numberOfBits <= 8) - { - uint num2 = (uint) (((uchar)data[2]) << 0x10); + if (numberOfBits <= 8) { + uint num2 = (uint)(((uchar)data[2]) << 0x10); endvalue = (value | num2); goto done; } - value |= (uint) (((uchar)data[2]) << 0x10); + value |= (uint)(((uchar)data[2]) << 0x10); numberOfBits -= 8; - endvalue = (value | ((uint) (((uchar)data[3]) << 0x18))); + endvalue = (value | ((uint)(((uchar)data[3]) << 0x18))); goto done; - done: +done: float num = max - min; - int num2 = (((int) 1) << numberOfBits) - 1; + int num2 = (((int)1) << numberOfBits) - 1; float num3 = endvalue; - float num4 = num3 / ((float) num2); + float num4 = num3 / ((float)num2); return (min + (num4 * num)); } @@ -145,30 +142,27 @@ QByteArray rangedSingleToData(float value, float min, float max, int numberOfBit QByteArray data; float num = max - min; float num2 = (value - min) / num; - int num3 = (((int) 1) << numberOfBits) - 1; + int num3 = (((int)1) << numberOfBits) - 1; uint source = num3 * num2; - if (numberOfBits <= 8) - { + if (numberOfBits <= 8) { data += (unsigned char)source; return data; } data += (unsigned char)source; numberOfBits -= 8; - if (numberOfBits <= 8) - { - data += (unsigned char)(source>>8); + if (numberOfBits <= 8) { + data += (unsigned char)(source >> 8); return data; } - data += (unsigned char)(source>>8); + data += (unsigned char)(source >> 8); numberOfBits -= 8; - if (numberOfBits <= 8) - { - data += (unsigned char)(source>>16); + if (numberOfBits <= 8) { + data += (unsigned char)(source >> 16); return data; } - data += (unsigned char)(source>>16); - data += (unsigned char)(source>>24); + data += (unsigned char)(source >> 16); + data += (unsigned char)(source >> 24); return data; } @@ -180,33 +174,26 @@ uint8_t dataToUint8(QByteArray data) uint16_t dataToUint16(QByteArray data) { - return ((uint16_t)(uint8_t)data[0]) - +(((uint16_t)(uint8_t)data[1])<<8); + return ((uint16_t)(uint8_t)data[0]) + (((uint16_t)(uint8_t)data[1]) << 8); } uint32_t dataToUint32(QByteArray data) { - return ((uint32_t)(uint8_t)data[0]) - +(((uint32_t)(uint8_t)data[1])<<8) - +(((uint32_t)(uint8_t)data[2])<<16) - +(((uint32_t)(uint8_t)data[3])<<24); + return ((uint32_t)(uint8_t)data[0]) + (((uint32_t)(uint8_t)data[1]) << 8) + + (((uint32_t)(uint8_t)data[2]) << 16) + (((uint32_t)(uint8_t)data[3]) << 24); } uint64_t dataToUint64(QByteArray data) { - return ((uint64_t)(uint8_t)data[0]) - +(((uint64_t)(uint8_t)data[1])<<8) - +(((uint64_t)(uint8_t)data[2])<<16) - +(((uint64_t)(uint8_t)data[3])<<24) - +(((uint64_t)(uint8_t)data[4])<<32) - +(((uint64_t)(uint8_t)data[5])<<40) - +(((uint64_t)(uint8_t)data[6])<<48) - +(((uint64_t)(uint8_t)data[7])<<56); + return ((uint64_t)(uint8_t)data[0]) + (((uint64_t)(uint8_t)data[1]) << 8) + + (((uint64_t)(uint8_t)data[2]) << 16) + (((uint64_t)(uint8_t)data[3]) << 24) + + (((uint64_t)(uint8_t)data[4]) << 32) + (((uint64_t)(uint8_t)data[5]) << 40) + + (((uint64_t)(uint8_t)data[6]) << 48) + (((uint64_t)(uint8_t)data[7]) << 56); } unsigned getVUint32Size(QByteArray data) { - unsigned lensize=0; + unsigned lensize = 0; { unsigned char num3; do { @@ -219,39 +206,39 @@ unsigned getVUint32Size(QByteArray data) QByteArray uint8ToData(uint8_t num) { - QByteArray data(1,0); + QByteArray data(1, 0); data[0] = (uint8_t)num; return data; } QByteArray uint16ToData(uint16_t num) { - QByteArray data(2,0); + QByteArray data(2, 0); data[0] = (uint8_t)(num & 0xFF); - data[1] = (uint8_t)((num>>8) & 0xFF); + data[1] = (uint8_t)((num >> 8) & 0xFF); return data; } QByteArray uint32ToData(uint32_t num) { - QByteArray data(4,0); + QByteArray data(4, 0); data[0] = (uint8_t)(num & 0xFF); - data[1] = (uint8_t)((num>>8) & 0xFF); - data[2] = (uint8_t)((num>>16) & 0xFF); - data[3] = (uint8_t)((num>>24) & 0xFF); + data[1] = (uint8_t)((num >> 8) & 0xFF); + data[2] = (uint8_t)((num >> 16) & 0xFF); + data[3] = (uint8_t)((num >> 24) & 0xFF); return data; } QByteArray uint64ToData(uint64_t num) { - QByteArray data(8,0); + QByteArray data(8, 0); data[0] = (uint8_t)(num & 0xFF); - data[1] = (uint8_t)((num>>8) & 0xFF); - data[2] = (uint8_t)((num>>16) & 0xFF); - data[3] = (uint8_t)((num>>24) & 0xFF); - data[4] = (uint8_t)((num>>32) & 0xFF); - data[5] = (uint8_t)((num>>40) & 0xFF); - data[6] = (uint8_t)((num>>48) & 0xFF); - data[7] = (uint8_t)((num>>56) & 0xFF); + data[1] = (uint8_t)((num >> 8) & 0xFF); + data[2] = (uint8_t)((num >> 16) & 0xFF); + data[3] = (uint8_t)((num >> 24) & 0xFF); + data[4] = (uint8_t)((num >> 32) & 0xFF); + data[5] = (uint8_t)((num >> 40) & 0xFF); + data[6] = (uint8_t)((num >> 48) & 0xFF); + data[7] = (uint8_t)((num >> 56) & 0xFF); return data; } diff --git a/updater/serialize.h b/updater/serialize.h index eb5cad62a..a74203419 100644 --- a/updater/serialize.h +++ b/updater/serialize.h @@ -21,9 +21,9 @@ #ifndef SERIALIZE_H #define SERIALIZE_H -#include #include #include +#include /// Most of those functions are unsafe unless otherwise specified /// Do not use them on untrusted data (e.g. check a signature first) diff --git a/updater/settings.cpp b/updater/settings.cpp old mode 100755 new mode 100644 index 670bc20a8..73737d9b8 --- a/updater/settings.cpp +++ b/updater/settings.cpp @@ -1,8 +1,8 @@ #include "settings.h" +#include +#include #include #include -#include -#include #include #ifdef Q_OS_WIN @@ -10,23 +10,22 @@ #undef _WIN32_WINNT #endif #define _WIN32_WINNT 0x0600 // Vista for SHGetKnownFolderPath -#include +#include #include #include -#include +#include #endif Settings::Settings() { portable = false; QFile portableSettings(SETTINGS_FILE); - if (portableSettings.exists()) - { + if (portableSettings.exists()) { QSettings ps(SETTINGS_FILE, QSettings::IniFormat); ps.beginGroup("General"); portable = ps.value("makeToxPortable", false).toBool(); } - qDebug() << "Portable: "< -#include -#include -#include #include +#include +#include +#include +#include -unsigned char key[crypto_sign_PUBLICKEYBYTES] = -{ - 0x20, 0x89, 0x39, 0xaa, 0x9a, 0xe8, 0xb5, 0x21, 0x0e, 0xac, 0x02, 0xa9, 0xc4, 0x92, 0xd9, 0xa2, - 0x17, 0x83, 0xbd, 0x78, 0x0a, 0xda, 0x33, 0xcd, 0xa5, 0xc6, 0x44, 0xc7, 0xfc, 0xed, 0x00, 0x13 -}; +unsigned char key[crypto_sign_PUBLICKEYBYTES] = {0x20, 0x89, 0x39, 0xaa, 0x9a, 0xe8, 0xb5, 0x21, + 0x0e, 0xac, 0x02, 0xa9, 0xc4, 0x92, 0xd9, 0xa2, + 0x17, 0x83, 0xbd, 0x78, 0x0a, 0xda, 0x33, 0xcd, + 0xa5, 0xc6, 0x44, 0xc7, 0xfc, 0xed, 0x00, 0x13}; QByteArray getLocalFlist() { QByteArray flist; QFile flistFile("flist"); - if (!flistFile.open(QIODevice::ReadOnly)) - { + if (!flistFile.open(QIODevice::ReadOnly)) { qWarning() << "getLocalFlist: Can't open local flist"; return flist; } @@ -53,7 +51,7 @@ QByteArray getLocalFlist() bool isUpToDate(UpdateFileMeta fileMeta) { QString appDir = qApp->applicationDirPath(); - QFile file(appDir+QDir::separator()+fileMeta.installpath); + QFile file(appDir + QDir::separator() + fileMeta.installpath); if (!file.open(QIODevice::ReadOnly)) return false; @@ -72,8 +70,7 @@ QList genUpdateDiff(QList updateFlist, Widget* w float progressDiff = 45; float progress = 5; - for (UpdateFileMeta file : updateFlist) - { + for (UpdateFileMeta file : updateFlist) { if (!isUpToDate(file)) diff += file; progress += progressDiff / updateFlist.size(); @@ -87,32 +84,27 @@ QList parseFlist(QByteArray flistData) { QList flist; - if (flistData.isEmpty()) - { + if (flistData.isEmpty()) { qWarning() << "AutoUpdater::parseflist: Empty data"; return flist; } // Check version - if (flistData[0] != '1') - { - qWarning() << "AutoUpdater: parseflist: Bad version "<<(uint8_t)flistData[0]; + if (flistData[0] != '1') { + qWarning() << "AutoUpdater: parseflist: Bad version " << (uint8_t)flistData[0]; return flist; } flistData = flistData.mid(1); // Check signature - if (flistData.size() < (int)(crypto_sign_BYTES)) - { + if (flistData.size() < (int)(crypto_sign_BYTES)) { qWarning() << "AutoUpdater::parseflist: Truncated data"; return flist; - } - else - { + } else { QByteArray msgData = flistData.mid(crypto_sign_BYTES); unsigned char* msg = (unsigned char*)msgData.data(); - if (crypto_sign_verify_detached((unsigned char*)flistData.data(), msg, msgData.size(), key) != 0) - { + if (crypto_sign_verify_detached((unsigned char*)flistData.data(), msg, msgData.size(), key) + != 0) { qCritical() << "AutoUpdater: parseflist: FORGED FLIST FILE"; return flist; } @@ -120,8 +112,7 @@ QList parseFlist(QByteArray flistData) } // Parse. We assume no errors handling needed since the signature is valid. - while (!flistData.isEmpty()) - { + while (!flistData.isEmpty()) { UpdateFileMeta newFile; memcpy(newFile.sig, flistData.data(), crypto_sign_BYTES); diff --git a/updater/update.h b/updater/update.h index 5dc866706..24b41c204 100644 --- a/updater/update.h +++ b/updater/update.h @@ -30,14 +30,14 @@ class Widget; struct UpdateFileMeta { unsigned char sig[crypto_sign_BYTES]; ///< Signature of the file (ed25519) - QString id; ///< Unique id of the file - QString installpath; ///< Local path including the file name. May be relative to qtox-updater or absolute - uint64_t size; ///< Size in bytes of the file + QString id; ///< Unique id of the file + QString installpath; ///< Local path including the file name. May be relative to qtox-updater or + ///absolute + uint64_t size; ///< Size in bytes of the file bool operator==(const UpdateFileMeta& other) { - return (size == other.size - && id == other.id && installpath == other.installpath + return (size == other.size && id == other.id && installpath == other.installpath && memcmp(sig, other.sig, crypto_sign_BYTES) == 0); } }; @@ -53,7 +53,7 @@ QByteArray getLocalFlist(); /// Parses and validates a flist file. Returns an empty list on error QList parseFlist(QByteArray flistData); /// Generates a list of files we need to update -QList genUpdateDiff(QList updateFlist, Widget *w); +QList genUpdateDiff(QList updateFlist, Widget* w); extern unsigned char key[crypto_sign_PUBLICKEYBYTES]; diff --git a/updater/widget.cpp b/updater/widget.cpp index 1ba67cc2e..3c4f31377 100644 --- a/updater/widget.cpp +++ b/updater/widget.cpp @@ -21,12 +21,12 @@ #include "widget.h" #include "ui_widget.h" +#include #include #include -#include #include #include -#include +#include #include #include @@ -37,10 +37,10 @@ #undef _WIN32_WINNT #endif #define _WIN32_WINNT 0x0600 // Vista for SHGetKnownFolderPath -#include +#include #include #include -#include +#include const bool supported = true; const QString QTOX_PATH = "qtox.exe"; @@ -50,10 +50,10 @@ const QString QTOX_PATH; #endif const QString SETTINGS_FILE = "settings.ini"; -Widget::Widget(const Settings &s) : - QWidget(nullptr), - ui(new Ui::Widget), - settings{s} +Widget::Widget(const Settings& s) + : QWidget(nullptr) + , ui(new Ui::Widget) + , settings{s} { ui->setupUi(this); @@ -78,8 +78,8 @@ void Widget::setProgress(int value) void Widget::fatalError(QString message) { - qCritical() << "Update aborted with error:"< diff = genUpdateDiff(updateFlist, this); for (UpdateFileMeta fileMeta : diff) - if (!QFile::exists(updateDirStr+fileMeta.installpath)) + if (!QFile::exists(updateDirStr + fileMeta.installpath)) fatalError(tr("The update is incomplete.")); if (diff.size() == 0) - fatalError(tr("The update is empty!")); + fatalError(tr("The update is empty!")); setProgress(50); - qDebug() << "Diff generated,"<