mirror of
https://github.com/dolphin-emu/dolphin.git
synced 2025-01-25 07:21:14 +01:00
Qt: avoid queuing ConfigChanged() more than once
This commit is contained in:
parent
fbf7e93f9b
commit
e6057c5f62
@ -4,6 +4,8 @@
|
|||||||
|
|
||||||
#include "DolphinQt/Settings.h"
|
#include "DolphinQt/Settings.h"
|
||||||
|
|
||||||
|
#include <atomic>
|
||||||
|
|
||||||
#include <QApplication>
|
#include <QApplication>
|
||||||
#include <QDir>
|
#include <QDir>
|
||||||
#include <QFile>
|
#include <QFile>
|
||||||
@ -41,8 +43,21 @@ Settings::Settings()
|
|||||||
QueueOnObject(this, [this, new_state] { emit EmulationStateChanged(new_state); });
|
QueueOnObject(this, [this, new_state] { emit EmulationStateChanged(new_state); });
|
||||||
});
|
});
|
||||||
|
|
||||||
Config::AddConfigChangedCallback(
|
Config::AddConfigChangedCallback([this] {
|
||||||
[this] { QueueOnObject(this, [this] { emit ConfigChanged(); }); });
|
static std::atomic<bool> do_once{true};
|
||||||
|
if (do_once.exchange(false))
|
||||||
|
{
|
||||||
|
// Calling ConfigChanged() with a "delay" can have risks, for example, if from
|
||||||
|
// code we change some configs that result in Qt greying out some setting, we could
|
||||||
|
// end up editing that setting before its greyed out, sending out an event,
|
||||||
|
// which might not be expected or handled by the code, potentially crashing.
|
||||||
|
// The only safe option would be to wait on the Qt thread to have finished executing this.
|
||||||
|
QueueOnObject(this, [this] {
|
||||||
|
do_once = true;
|
||||||
|
emit ConfigChanged();
|
||||||
|
});
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
g_controller_interface.RegisterDevicesChangedCallback(
|
g_controller_interface.RegisterDevicesChangedCallback(
|
||||||
[this] { QueueOnObject(this, [this] { emit DevicesChanged(); }); });
|
[this] { QueueOnObject(this, [this] { emit DevicesChanged(); }); });
|
||||||
|
Loading…
x
Reference in New Issue
Block a user