-
-
Notifications
You must be signed in to change notification settings - Fork 1.3k
Lambda Rules
Nazar Gerasymchuk edited this page Sep 22, 2013
·
4 revisions
- Beware of recursive lambda calls.
- All database access must be applied in separate thread
(
TrackCollections
thread). So all database access must be wrapped into lambda (viam_pTrackCollection->callAsync/callSync
).
- It is strictly prohibited to access GUI from lambda. GUI access must be be applied only from main thread.
- If you need to access GUI from lambda it can be done by emitting
signal (
ConnectionType
must beQt::QueuedConnection
. - All access to GUI moves to separate private slot (
slotChangeUI
). - Signal must be created (
changeUI
). -
changeUI
connects toslotChangeUI
with last parameterQt::QueuedConnection
. -
OR You can use helper class
MainExecuter
, which is constructed likeTrackCollection
and has its methodscallSync/callAsync
. UsingMainExecuter
you must wrap UI access to lambda.
Example.
Please, take a look at DlgMissing::onShow()
. Here we must disable
button after calling m_pMissingTableModel->select();
So we created: private slots: void slotActivateButtons(bool enable);
connect it: connect(this, SIGNAL(activateButtons(bool)), this, SLOT(slotActivateButtons(bool)), Qt::QueuedConnection);
and call it from the lambda inside DlgMissing::onShow()
:
// tro's lambda idea
m_pTrackCollection->callAsync(
[this] (void) {
m_pMissingTableModel->select();
// no buttons can be selected
emit(activateButtons(false));
});
Mixxx is a free and open-source DJ software.
Manual
Hardware Compatibility
Reporting Bugs
Getting Involved
Contribution Guidelines
Coding Guidelines
Using Git
Developer Guide
Creating Skins
Contributing Mappings
Mixxx Controls
MIDI Scripting
Components JS
HID Scripting