From 5d0df5d28ec3deffaee0d8ca4d6bd5356616021c Mon Sep 17 00:00:00 2001 From: Albert Vaca Cintora Date: Thu, 25 May 2023 16:59:41 +0200 Subject: [PATCH] Do not send the sink list a thousand times When a device is connected/disconnected those callbacks would fire a lot --- plugins/systemvolume/systemvolumeplugin-win.cpp | 15 +++++++++++---- 1 file changed, 11 insertions(+), 4 deletions(-) diff --git a/plugins/systemvolume/systemvolumeplugin-win.cpp b/plugins/systemvolume/systemvolumeplugin-win.cpp index 5c310fc09..19634e8b5 100644 --- a/plugins/systemvolume/systemvolumeplugin-win.cpp +++ b/plugins/systemvolume/systemvolumeplugin-win.cpp @@ -72,7 +72,6 @@ public: HRESULT STDMETHODCALLTYPE OnNotify(PAUDIO_VOLUME_NOTIFICATION_DATA pNotify) override { - qWarning("OnNotify"); NetworkPacket np(PACKET_TYPE_SYSTEMVOLUME); np.set(QStringLiteral("volume"), (int)(pNotify->fMasterVolume * 100)); np.set(QStringLiteral("muted"), pNotify->bMuted); @@ -188,6 +187,8 @@ public: HANDLE threadHandle = CreateThread(NULL, 0, releaseRemovedDevice, &data, 0, &threadId); CloseHandle(threadHandle); + enclosing.sendSinkList(); + return S_OK; } @@ -195,14 +196,20 @@ public: { if (dwNewState == DEVICE_STATE_UNPLUGGED) return OnDeviceRemoved(pwstrDeviceId); - - enclosing.sendSinkList(); return S_OK; } HRESULT STDMETHODCALLTYPE OnPropertyValueChanged(LPCWSTR pwstrDeviceId, const PROPERTYKEY key) override { - enclosing.sendSinkList(); + // This callback is supper spammy. Care only about name and description changes. + if (IsEqualPropertyKey(key, PKEY_Device_FriendlyName)) { + enclosing.sendSinkList(); + } +#ifndef __MINGW32__ + else if (IsEqualPropertyKey(key, PKEY_Device_DeviceDesc)) { + enclosing.sendSinkList(); + } +#endif return S_OK; }