From d5f2249dcebe92662e58578b80e03a8809172bdb Mon Sep 17 00:00:00 2001 From: Jan Holthuis Date: Thu, 15 Jul 2021 14:04:13 +0200 Subject: [PATCH 01/25] ControlProxy: Use doxygen-style `///` comments --- src/control/controlproxy.h | 46 +++++++++++++++++++------------------- 1 file changed, 23 insertions(+), 23 deletions(-) diff --git a/src/control/controlproxy.h b/src/control/controlproxy.h index 4eab2fa38d1..9fda204403f 100644 --- a/src/control/controlproxy.h +++ b/src/control/controlproxy.h @@ -8,13 +8,13 @@ #include "preferences/usersettings.h" #include "util/platform.h" -// This class is the successor of ControlObjectThread. It should be used for -// new code to avoid unnecessary locking during send if no slot is connected. -// Do not (re-)connect slots during runtime, since this locks the mutex in -// QMetaObject::activate(). -// Be sure that the ControlProxy is created and deleted from the same -// thread, otherwise a pending signal may lead to a segfault (Bug #1406124). -// Parent it to the the creating object to achieve this. +/// This class is the successor of ControlObjectThread. It should be used for +/// new code to avoid unnecessary locking during send if no slot is connected. +/// Do not (re-)connect slots during runtime, since this locks the mutex in +/// QMetaObject::activate(). +/// Be sure that the ControlProxy is created and deleted from the same +/// thread, otherwise a pending signal may lead to a segfault (Bug #1406124). +/// Parent it to the the creating object to achieve this. class ControlProxy : public QObject { Q_OBJECT public: @@ -108,7 +108,7 @@ class ControlProxy : public QObject { return true; } - // Called from update(); + /// Called from update(); virtual void emitValueChanged() { emit valueChanged(get()); } @@ -117,49 +117,49 @@ class ControlProxy : public QObject { return m_pControl != nullptr; } - // Returns the value of the object. Thread safe, non-blocking. + /// Returns the value of the object. Thread safe, non-blocking. inline double get() const { return m_pControl ? m_pControl->get() : 0.0; } - // Returns the bool interpretation of the value + /// Returns the bool interpretation of the value. Thread safe, non-blocking. inline bool toBool() const { return get() > 0.0; } - // Returns the parameterized value of the object. Thread safe, non-blocking. + /// Returns the parameterized value of the object. Thread safe, non-blocking. inline double getParameter() const { return m_pControl ? m_pControl->getParameter() : 0.0; } - // Returns the parameterized value of the object. Thread safe, non-blocking. + /// Returns the parameterized value of the object. Thread safe, non-blocking. inline double getParameterForValue(double value) const { return m_pControl ? m_pControl->getParameterForValue(value) : 0.0; } - // Returns the normalized parameter of the object. Thread safe, non-blocking. + /// Returns the normalized parameter of the object. Thread safe, non-blocking. inline double getDefault() const { return m_pControl ? m_pControl->defaultValue() : 0.0; } public slots: - // Set the control to a new value. Non-blocking. + /// Set the control to a new value. Non-blocking. inline void slotSet(double v) { set(v); } - // Sets the control value to v. Thread safe, non-blocking. + /// Sets the control value to v. Thread safe, non-blocking. void set(double v) { if (m_pControl) { m_pControl->set(v, this); } } - // Sets the control parameterized value to v. Thread safe, non-blocking. + /// Sets the control parameterized value to v. Thread safe, non-blocking. void setParameter(double v) { if (m_pControl) { m_pControl->setParameter(v, this); } } - // Resets the control to its default value. Thread safe, non-blocking. + /// Resets the control to its default value. Thread safe, non-blocking. void reset() { if (m_pControl) { // NOTE(rryan): This is important. The originator of this action does @@ -172,12 +172,12 @@ class ControlProxy : public QObject { } signals: - // This signal must not connected by connect(). Use connectValueChanged() - // instead. It will connect to the base ControlDoublePrivate as well. + /// This signal must not connected by connect(). Use connectValueChanged() + /// instead. It will connect to the base ControlDoublePrivate as well. void valueChanged(double); protected slots: - // Receives the value from the master control by a unique direct connection + /// Receives the value from the master control by a unique direct connection void slotValueChangedDirect(double v, QObject* pSetter) { if (pSetter != this) { // This is base implementation of this function without scaling @@ -185,7 +185,7 @@ class ControlProxy : public QObject { } } - // Receives the value from the master control by a unique auto connection + /// Receives the value from the master control by a unique auto connection void slotValueChangedAuto(double v, QObject* pSetter) { if (pSetter != this) { // This is base implementation of this function without scaling @@ -193,7 +193,7 @@ class ControlProxy : public QObject { } } - // Receives the value from the master control by a unique Queued connection + /// Receives the value from the master control by a unique Queued connection void slotValueChangedQueued(double v, QObject* pSetter) { if (pSetter != this) { // This is base implementation of this function without scaling @@ -203,6 +203,6 @@ class ControlProxy : public QObject { protected: ConfigKey m_key; - // Pointer to connected control. + /// Pointer to connected control. QSharedPointer m_pControl; }; From 0f0ca5477b20c5deec8854f01bdfedd1173d6577 Mon Sep 17 00:00:00 2001 From: Jan Holthuis Date: Thu, 15 Jul 2021 14:14:07 +0200 Subject: [PATCH 02/25] Remove useless ControlProxy::slotSet() method This just calls `set`, which is nicer to read anyway. --- src/control/controlproxy.h | 4 - .../controllerscriptinterfacelegacy.cpp | 22 +- src/engine/sidechain/enginerecord.cpp | 6 +- src/preferences/dialog/dlgprefvinyl.cpp | 12 +- src/test/cuecontrol_test.cpp | 32 +- src/test/enginesynctest.cpp | 84 ++-- src/test/hotcuecontrol_test.cpp | 408 +++++++++--------- src/test/looping_control_test.cpp | 228 +++++----- src/vinylcontrol/vinylcontrol.cpp | 10 +- src/vinylcontrol/vinylcontrolxwax.cpp | 47 +- src/widget/wwaveformviewer.cpp | 4 +- 11 files changed, 427 insertions(+), 430 deletions(-) diff --git a/src/control/controlproxy.h b/src/control/controlproxy.h index 9fda204403f..be6adc1b124 100644 --- a/src/control/controlproxy.h +++ b/src/control/controlproxy.h @@ -143,10 +143,6 @@ class ControlProxy : public QObject { } public slots: - /// Set the control to a new value. Non-blocking. - inline void slotSet(double v) { - set(v); - } /// Sets the control value to v. Thread safe, non-blocking. void set(double v) { if (m_pControl) { diff --git a/src/controllers/scripting/legacy/controllerscriptinterfacelegacy.cpp b/src/controllers/scripting/legacy/controllerscriptinterfacelegacy.cpp index 581de5d377a..40a46f544f9 100644 --- a/src/controllers/scripting/legacy/controllerscriptinterfacelegacy.cpp +++ b/src/controllers/scripting/legacy/controllerscriptinterfacelegacy.cpp @@ -126,7 +126,7 @@ void ControllerScriptInterfaceLegacy::setValue( if (pControl && !m_st.ignore( pControl, coScript->getParameterForValue(newValue))) { - coScript->slotSet(newValue); + coScript->set(newValue); } } } @@ -621,7 +621,7 @@ void ControllerScriptInterfaceLegacy::scratchEnable(int deck, // Set scratch2_enable if (pScratch2Enable != nullptr) { - pScratch2Enable->slotSet(1); + pScratch2Enable->set(1); } } @@ -688,10 +688,10 @@ void ControllerScriptInterfaceLegacy::scratchProcess(int timerId) { if (m_brakeActive[deck]) { // If in brake mode, set scratch2 rate to 0 and turn off the play button. - pScratch2->slotSet(0.0); + pScratch2->set(0.0); ControlObjectScript* pPlay = getControlObjectScript(group, "play"); if (pPlay != nullptr) { - pPlay->slotSet(0.0); + pPlay->set(0.0); } } @@ -701,7 +701,7 @@ void ControllerScriptInterfaceLegacy::scratchProcess(int timerId) { if (pScratch2Enable == nullptr) { return; // abort and maybe it'll work on the next pass } - pScratch2Enable->slotSet(0); + pScratch2Enable->set(0); // Remove timer killTimer(timerId); @@ -724,7 +724,7 @@ void ControllerScriptInterfaceLegacy::scratchDisable(int deck, bool ramp) { // Clear scratch2_enable ControlObjectScript* pScratch2Enable = getControlObjectScript(group, "scratch2_enable"); if (pScratch2Enable != nullptr) { - pScratch2Enable->slotSet(0); + pScratch2Enable->set(0); } // Can't return here because we need scratchProcess to stop the timer. // So it's still actually ramping, we just won't hear or see it. @@ -761,7 +761,7 @@ void ControllerScriptInterfaceLegacy::brake(int deck, bool activate, double fact // enable/disable scratch2 mode ControlObjectScript* pScratch2Enable = getControlObjectScript(group, "scratch2_enable"); if (pScratch2Enable != nullptr) { - pScratch2Enable->slotSet(activate ? 1 : 0); + pScratch2Enable->set(activate ? 1 : 0); } // used in scratchProcess for the different timer behavior we need @@ -792,7 +792,7 @@ void ControllerScriptInterfaceLegacy::brake(int deck, bool activate, double fact ControlObjectScript* pScratch2 = getControlObjectScript(group, "scratch2"); if (pScratch2 != nullptr) { - pScratch2->slotSet(initRate); + pScratch2->set(initRate); } // setup the filter with default alpha and beta*factor @@ -824,7 +824,7 @@ void ControllerScriptInterfaceLegacy::softStart(int deck, bool activate, double // enable/disable scratch2 mode ControlObjectScript* pScratch2Enable = getControlObjectScript(group, "scratch2_enable"); if (pScratch2Enable != nullptr) { - pScratch2Enable->slotSet(activate ? 1 : 0); + pScratch2Enable->set(activate ? 1 : 0); } // used in scratchProcess for the different timer behavior we need @@ -851,12 +851,12 @@ void ControllerScriptInterfaceLegacy::softStart(int deck, bool activate, double ControlObjectScript* pPlay = getControlObjectScript(group, "play"); if (pPlay != nullptr) { - pPlay->slotSet(1.0); + pPlay->set(1.0); } ControlObjectScript* pScratch2 = getControlObjectScript(group, "scratch2"); if (pScratch2 != nullptr) { - pScratch2->slotSet(initRate); + pScratch2->set(initRate); } // setup the filter like in brake(), with default alpha and beta*factor diff --git a/src/engine/sidechain/enginerecord.cpp b/src/engine/sidechain/enginerecord.cpp index 39b9beb949e..a2678a8eed2 100644 --- a/src/engine/sidechain/enginerecord.cpp +++ b/src/engine/sidechain/enginerecord.cpp @@ -132,7 +132,7 @@ void EngineRecord::process(const CSAMPLE* pBuffer, const int iBufferSize) { if (updateFromPreferences() < 0) { // Maybe the encoder could not be initialized qDebug() << "Setting record flag to: OFF"; - m_pRecReady->slotSet(RECORD_OFF); + m_pRecReady->set(RECORD_OFF); // Just report that we don't record // There was already a message Box emit isRecording(false, false); @@ -157,7 +157,7 @@ void EngineRecord::process(const CSAMPLE* pBuffer, const int iBufferSize) { } else { qDebug() << "Could not open" << m_fileName << "for writing."; qDebug("Setting record flag to: OFF"); - m_pRecReady->slotSet(RECORD_OFF); + m_pRecReady->set(RECORD_OFF); // An error occurred. emit isRecording(false, true); } @@ -191,7 +191,7 @@ void EngineRecord::process(const CSAMPLE* pBuffer, const int iBufferSize) { qDebug() << "Could not open" << m_fileName << "for writing."; Event::end(tag); qDebug("Setting record flag to: OFF"); - m_pRecReady->slotSet(RECORD_OFF); + m_pRecReady->set(RECORD_OFF); // An error occurred. emit isRecording(false, true); } diff --git a/src/preferences/dialog/dlgprefvinyl.cpp b/src/preferences/dialog/dlgprefvinyl.cpp index 4ace21efec5..ac611a86ace 100644 --- a/src/preferences/dialog/dlgprefvinyl.cpp +++ b/src/preferences/dialog/dlgprefvinyl.cpp @@ -358,23 +358,23 @@ void DlgPrefVinyl::VinylTypeSlotApply() M_FALLTHROUGH_INTENDED; case 3: if (ComboBoxVinylSpeed3->currentText() == MIXXX_VINYL_SPEED_33) { - m_COSpeeds[2]->slotSet(MIXXX_VINYL_SPEED_33_NUM); + m_COSpeeds[2]->set(MIXXX_VINYL_SPEED_33_NUM); } else if (ComboBoxVinylSpeed3->currentText() == MIXXX_VINYL_SPEED_45) { - m_COSpeeds[2]->slotSet(MIXXX_VINYL_SPEED_45_NUM); + m_COSpeeds[2]->set(MIXXX_VINYL_SPEED_45_NUM); } M_FALLTHROUGH_INTENDED; case 2: if (ComboBoxVinylSpeed2->currentText() == MIXXX_VINYL_SPEED_33) { - m_COSpeeds[1]->slotSet(MIXXX_VINYL_SPEED_33_NUM); + m_COSpeeds[1]->set(MIXXX_VINYL_SPEED_33_NUM); } else if (ComboBoxVinylSpeed2->currentText() == MIXXX_VINYL_SPEED_45) { - m_COSpeeds[1]->slotSet(MIXXX_VINYL_SPEED_45_NUM); + m_COSpeeds[1]->set(MIXXX_VINYL_SPEED_45_NUM); } M_FALLTHROUGH_INTENDED; case 1: if (ComboBoxVinylSpeed1->currentText() == MIXXX_VINYL_SPEED_33) { - m_COSpeeds[0]->slotSet(MIXXX_VINYL_SPEED_33_NUM); + m_COSpeeds[0]->set(MIXXX_VINYL_SPEED_33_NUM); } else if (ComboBoxVinylSpeed1->currentText() == MIXXX_VINYL_SPEED_45) { - m_COSpeeds[0]->slotSet(MIXXX_VINYL_SPEED_45_NUM); + m_COSpeeds[0]->set(MIXXX_VINYL_SPEED_45_NUM); } break; default: diff --git a/src/test/cuecontrol_test.cpp b/src/test/cuecontrol_test.cpp index 05abf547adb..59d88c94c7d 100644 --- a/src/test/cuecontrol_test.cpp +++ b/src/test/cuecontrol_test.cpp @@ -424,8 +424,8 @@ TEST_F(CueControlTest, IntroCue_SetStartEnd_ClearStartEnd) { // Set intro start cue setCurrentFramePos(mixxx::audio::FramePos(100.0)); - m_pIntroStartSet->slotSet(1); - m_pIntroStartSet->slotSet(0); + m_pIntroStartSet->set(1); + m_pIntroStartSet->set(0); EXPECT_FRAMEPOS_EQ_CONTROL(mixxx::audio::FramePos(100.0), m_pIntroStartPosition); EXPECT_TRUE(m_pIntroStartEnabled->toBool()); EXPECT_FRAMEPOS_EQ_CONTROL(mixxx::audio::kInvalidFramePos, m_pIntroEndPosition); @@ -440,8 +440,8 @@ TEST_F(CueControlTest, IntroCue_SetStartEnd_ClearStartEnd) { // Set intro end cue setCurrentFramePos(mixxx::audio::FramePos(500.0)); - m_pIntroEndSet->slotSet(1); - m_pIntroEndSet->slotSet(0); + m_pIntroEndSet->set(1); + m_pIntroEndSet->set(0); EXPECT_FRAMEPOS_EQ_CONTROL(mixxx::audio::FramePos(100.0), m_pIntroStartPosition); EXPECT_TRUE(m_pIntroStartEnabled->toBool()); EXPECT_FRAMEPOS_EQ_CONTROL(mixxx::audio::FramePos(500.0), m_pIntroEndPosition); @@ -455,8 +455,8 @@ TEST_F(CueControlTest, IntroCue_SetStartEnd_ClearStartEnd) { } // Clear intro start cue - m_pIntroStartClear->slotSet(1); - m_pIntroStartClear->slotSet(0); + m_pIntroStartClear->set(1); + m_pIntroStartClear->set(0); EXPECT_FRAMEPOS_EQ_CONTROL(mixxx::audio::kInvalidFramePos, m_pIntroStartPosition); EXPECT_FALSE(m_pIntroStartEnabled->toBool()); EXPECT_FRAMEPOS_EQ_CONTROL(mixxx::audio::FramePos(500.0), m_pIntroEndPosition); @@ -470,8 +470,8 @@ TEST_F(CueControlTest, IntroCue_SetStartEnd_ClearStartEnd) { } // Clear intro end cue - m_pIntroEndClear->slotSet(1); - m_pIntroEndClear->slotSet(0); + m_pIntroEndClear->set(1); + m_pIntroEndClear->set(0); EXPECT_FRAMEPOS_EQ_CONTROL(mixxx::audio::kInvalidFramePos, m_pIntroStartPosition); EXPECT_FALSE(m_pIntroStartEnabled->toBool()); EXPECT_FRAMEPOS_EQ_CONTROL(mixxx::audio::kInvalidFramePos, m_pIntroEndPosition); @@ -485,8 +485,8 @@ TEST_F(CueControlTest, OutroCue_SetStartEnd_ClearStartEnd) { // Set outro start cue setCurrentFramePos(mixxx::audio::FramePos(750.0)); - m_pOutroStartSet->slotSet(1); - m_pOutroStartSet->slotSet(0); + m_pOutroStartSet->set(1); + m_pOutroStartSet->set(0); EXPECT_FRAMEPOS_EQ_CONTROL(mixxx::audio::FramePos(750.0), m_pOutroStartPosition); EXPECT_TRUE(m_pOutroStartEnabled->toBool()); EXPECT_FRAMEPOS_EQ_CONTROL(mixxx::audio::kInvalidFramePos, m_pOutroEndPosition); @@ -501,8 +501,8 @@ TEST_F(CueControlTest, OutroCue_SetStartEnd_ClearStartEnd) { // Set outro end cue setCurrentFramePos(mixxx::audio::FramePos(1000.0)); - m_pOutroEndSet->slotSet(1); - m_pOutroEndSet->slotSet(0); + m_pOutroEndSet->set(1); + m_pOutroEndSet->set(0); EXPECT_FRAMEPOS_EQ_CONTROL(mixxx::audio::FramePos(750.0), m_pOutroStartPosition); EXPECT_TRUE(m_pOutroStartEnabled->toBool()); EXPECT_FRAMEPOS_EQ_CONTROL(mixxx::audio::FramePos(1000.0), m_pOutroEndPosition); @@ -516,8 +516,8 @@ TEST_F(CueControlTest, OutroCue_SetStartEnd_ClearStartEnd) { } // Clear outro start cue - m_pOutroStartClear->slotSet(1); - m_pOutroStartClear->slotSet(0); + m_pOutroStartClear->set(1); + m_pOutroStartClear->set(0); EXPECT_FRAMEPOS_EQ_CONTROL(mixxx::audio::kInvalidFramePos, m_pOutroStartPosition); EXPECT_FALSE(m_pOutroStartEnabled->toBool()); EXPECT_FRAMEPOS_EQ_CONTROL(mixxx::audio::FramePos(1000.0), m_pOutroEndPosition); @@ -531,8 +531,8 @@ TEST_F(CueControlTest, OutroCue_SetStartEnd_ClearStartEnd) { } // Clear outro end cue - m_pOutroEndClear->slotSet(1); - m_pOutroEndClear->slotSet(0); + m_pOutroEndClear->set(1); + m_pOutroEndClear->set(0); EXPECT_FRAMEPOS_EQ_CONTROL(mixxx::audio::kInvalidFramePos, m_pOutroStartPosition); EXPECT_FALSE(m_pOutroStartEnabled->toBool()); EXPECT_FRAMEPOS_EQ_CONTROL(mixxx::audio::kInvalidFramePos, m_pOutroEndPosition); diff --git a/src/test/enginesynctest.cpp b/src/test/enginesynctest.cpp index 0a9d2423a3b..29d5f124352 100644 --- a/src/test/enginesynctest.cpp +++ b/src/test/enginesynctest.cpp @@ -199,7 +199,7 @@ TEST_F(EngineSyncTest, SetMasterSuccess) { auto pButtonMasterSync1 = std::make_unique(m_sGroup1, "sync_mode"); - pButtonMasterSync1->slotSet(SYNC_MASTER_EXPLICIT); + pButtonMasterSync1->set(SYNC_MASTER_EXPLICIT); ProcessBuffer(); // No tracks are playing and we have no beats, SYNC_MASTER_EXPLICIT state is in stand-by @@ -233,7 +233,7 @@ TEST_F(EngineSyncTest, SetMasterSuccess) { EXPECT_TRUE(isFollower(m_sGroup2)); // Now set channel 1 to follower, now all are followers, waiting for a tempo to adopt. - pButtonMasterSync1->slotSet(SYNC_FOLLOWER); + pButtonMasterSync1->set(SYNC_FOLLOWER); ProcessBuffer(); EXPECT_TRUE(isFollower(m_sInternalClockGroup)); @@ -254,7 +254,7 @@ TEST_F(EngineSyncTest, ExplicitMasterPersists) { auto pButtonMasterSync1 = std::make_unique(m_sGroup1, "sync_mode"); ControlObject::getControl(ConfigKey(m_sGroup1, "play"))->set(1.0); - pButtonMasterSync1->slotSet(SYNC_MASTER_EXPLICIT); + pButtonMasterSync1->set(SYNC_MASTER_EXPLICIT); ProcessBuffer(); // The master sync should now be channel 1. EXPECT_TRUE(isExplicitMaster(m_sGroup1)); @@ -293,10 +293,10 @@ TEST_F(EngineSyncTest, SetMasterWhilePlaying) { pButtonMasterSync1->set(SYNC_MASTER_EXPLICIT); auto pButtonMasterSync2 = std::make_unique(m_sGroup2, "sync_mode"); - pButtonMasterSync2->slotSet(SYNC_FOLLOWER); + pButtonMasterSync2->set(SYNC_FOLLOWER); auto pButtonMasterSync3 = std::make_unique(m_sGroup3, "sync_mode"); - pButtonMasterSync3->slotSet(SYNC_FOLLOWER); + pButtonMasterSync3->set(SYNC_FOLLOWER); ControlObject::getControl(ConfigKey(m_sGroup1, "play"))->set(1.0); ControlObject::getControl(ConfigKey(m_sGroup2, "play"))->set(1.0); @@ -304,7 +304,7 @@ TEST_F(EngineSyncTest, SetMasterWhilePlaying) { ProcessBuffer(); - pButtonMasterSync3->slotSet(SYNC_MASTER_EXPLICIT); + pButtonMasterSync3->set(SYNC_MASTER_EXPLICIT); ProcessBuffer(); @@ -320,7 +320,7 @@ TEST_F(EngineSyncTest, SetEnabledBecomesMaster) { m_pTrack1->trySetBeats(pBeats1); auto pButtonMasterSync1 = std::make_unique(m_sGroup1, "sync_mode"); - pButtonMasterSync1->slotSet(SYNC_FOLLOWER); + pButtonMasterSync1->set(SYNC_FOLLOWER); ProcessBuffer(); EXPECT_TRUE(isSoftMaster(m_sGroup1)); @@ -330,13 +330,13 @@ TEST_F(EngineSyncTest, SetEnabledBecomesMaster) { TEST_F(EngineSyncTest, DisableInternalMasterWhilePlaying) { auto pButtonMasterSync = std::make_unique( m_sInternalClockGroup, "sync_master"); - pButtonMasterSync->slotSet(1.0); + pButtonMasterSync->set(1.0); auto pButtonSyncMode1 = std::make_unique(m_sGroup1, "sync_mode"); - pButtonSyncMode1->slotSet(SYNC_FOLLOWER); + pButtonSyncMode1->set(SYNC_FOLLOWER); auto pButtonSyncMode2 = std::make_unique(m_sGroup2, "sync_mode"); - pButtonSyncMode2->slotSet(SYNC_FOLLOWER); + pButtonSyncMode2->set(SYNC_FOLLOWER); ProcessBuffer(); // The master sync should now be Internal. EXPECT_TRUE(isExplicitMaster(m_sInternalClockGroup)); @@ -353,7 +353,7 @@ TEST_F(EngineSyncTest, DisableInternalMasterWhilePlaying) { ProcessBuffer(); // Now unset Internal master. - pButtonMasterSync->slotSet(0.0); + pButtonMasterSync->set(0.0); ProcessBuffer(); // This is not allowed, Internal should still be master. @@ -368,7 +368,7 @@ TEST_F(EngineSyncTest, DisableSyncOnMaster) { m_pTrack1->trySetBeats(pBeats1); auto pButtonSyncMode1 = std::make_unique(m_sGroup1, "sync_mode"); - pButtonSyncMode1->slotSet(SYNC_FOLLOWER); + pButtonSyncMode1->set(SYNC_FOLLOWER); mixxx::BeatsPointer pBeats2 = BeatFactory::makeBeatGrid( m_pTrack2->getSampleRate(), mixxx::Bpm(130), mixxx::audio::kStartFramePos); @@ -376,7 +376,7 @@ TEST_F(EngineSyncTest, DisableSyncOnMaster) { // Set deck two to explicit master. auto pButtonSyncMaster2 = std::make_unique(m_sGroup2, "sync_master"); - pButtonSyncMaster2->slotSet(1.0); + pButtonSyncMaster2->set(1.0); ProcessBuffer(); EXPECT_TRUE(isFollower(m_sGroup1)); EXPECT_TRUE(isExplicitMaster(m_sGroup2)); @@ -391,7 +391,7 @@ TEST_F(EngineSyncTest, DisableSyncOnMaster) { // Unset enabled on channel2, it should work. auto pButtonSyncEnabled2 = std::make_unique(m_sGroup2, "sync_enabled"); - pButtonSyncEnabled2->slotSet(0.0); + pButtonSyncEnabled2->set(0.0); ProcessBuffer(); EXPECT_TRUE(isSoftMaster(m_sGroup1)); EXPECT_EQ(0, ControlObject::getControl(ConfigKey(m_sGroup2, "sync_enabled"))->get()); @@ -406,7 +406,7 @@ TEST_F(EngineSyncTest, InternalMasterSetFollowerSliderMoves) { std::make_unique(m_sInternalClockGroup, "bpm"); pMasterSyncSlider->set(100.0); - pButtonMasterSyncInternal->slotSet(1); + pButtonMasterSyncInternal->set(1); // Set the file bpm of channel 1 to 80 bpm. mixxx::BeatsPointer pBeats1 = BeatFactory::makeBeatGrid( @@ -415,7 +415,7 @@ TEST_F(EngineSyncTest, InternalMasterSetFollowerSliderMoves) { auto pButtonMasterSync1 = std::make_unique(m_sGroup1, "sync_mode"); - pButtonMasterSync1->slotSet(SYNC_FOLLOWER); + pButtonMasterSync1->set(SYNC_FOLLOWER); ProcessBuffer(); EXPECT_DOUBLE_EQ(getRateSliderValue(1.25), @@ -549,20 +549,20 @@ TEST_F(EngineSyncTest, SetExplicitMasterByLights) { ControlObject::set(ConfigKey(m_sGroup2, "play"), 1.0); // Set channel 1 to be explicit master. - pButtonSyncMaster1->slotSet(1.0); + pButtonSyncMaster1->set(1.0); ProcessBuffer(); // The master sync should now be channel 1. EXPECT_TRUE(isExplicitMaster(m_sGroup1)); // Set channel 2 to be follower. - pButtonSyncEnabled2->slotSet(1); + pButtonSyncEnabled2->set(1); ProcessBuffer(); EXPECT_TRUE(isFollower(m_sGroup2)); // Now set channel 2 to be master. - pButtonSyncMaster2->slotSet(1); + pButtonSyncMaster2->set(1); ProcessBuffer(); // Now channel 2 should be master, and channel 1 should be a follower. @@ -570,7 +570,7 @@ TEST_F(EngineSyncTest, SetExplicitMasterByLights) { EXPECT_TRUE(isExplicitMaster(m_sGroup2)); // Now back again. - pButtonSyncMaster1->slotSet(1); + pButtonSyncMaster1->set(1); ProcessBuffer(); // Now channel 1 should be master, and channel 2 should be a follower. @@ -579,7 +579,7 @@ TEST_F(EngineSyncTest, SetExplicitMasterByLights) { // Now set channel 1 to not-master. The system will choose deck 2 as the next best // option for soft master - pButtonSyncMaster1->slotSet(0); + pButtonSyncMaster1->set(0); ProcessBuffer(); EXPECT_TRUE(isFollower(m_sInternalClockGroup)); @@ -594,16 +594,16 @@ TEST_F(EngineSyncTest, SetExplicitMasterByLightsNoTracks) { auto pButtonSyncMaster1 = std::make_unique(m_sGroup1, "sync_master"); - pButtonSyncMaster1->slotSet(1); + pButtonSyncMaster1->set(1); // Set channel 2 to be follower. - pButtonSyncEnabled2->slotSet(1); + pButtonSyncEnabled2->set(1); // Without a track loaded, deck 1 can't be an explicit master. EXPECT_TRUE(isFollower(m_sGroup1)); EXPECT_TRUE(isFollower(m_sGroup2)); - pButtonSyncMaster1->slotSet(0); + pButtonSyncMaster1->set(0); EXPECT_TRUE(isFollower(m_sGroup1)); EXPECT_TRUE(isFollower(m_sGroup2)); @@ -656,10 +656,10 @@ TEST_F(EngineSyncTest, RateChangeTestWeirdOrder) { // This is like the test above, but the user loads the track after the slider has been tweaked. auto pButtonMasterSync1 = std::make_unique(m_sGroup1, "sync_mode"); - pButtonMasterSync1->slotSet(SYNC_MASTER_EXPLICIT); + pButtonMasterSync1->set(SYNC_MASTER_EXPLICIT); auto pButtonMasterSync2 = std::make_unique(m_sGroup2, "sync_mode"); - pButtonMasterSync2->slotSet(SYNC_FOLLOWER); + pButtonMasterSync2->set(SYNC_FOLLOWER); ProcessBuffer(); // Set the file bpm of channel 1 to 160bpm. @@ -848,10 +848,10 @@ TEST_F(EngineSyncTest, MasterStopSliderCheck) { auto pButtonMasterSync1 = std::make_unique(m_sGroup1, "sync_mode"); - pButtonMasterSync1->slotSet(SYNC_MASTER_EXPLICIT); + pButtonMasterSync1->set(SYNC_MASTER_EXPLICIT); auto pButtonMasterSync2 = std::make_unique(m_sGroup2, "sync_mode"); - pButtonMasterSync2->slotSet(SYNC_FOLLOWER); + pButtonMasterSync2->set(SYNC_FOLLOWER); ProcessBuffer(); //EXPECT_TRUE(isExplicitMaster(m_sGroup1)); @@ -953,8 +953,8 @@ TEST_F(EngineSyncTest, MomentarySyncAlgorithmTwo) { auto pButtonSyncEnabled1 = std::make_unique(m_sGroup1, "sync_enabled"); - pButtonSyncEnabled1->slotSet(1.0); - pButtonSyncEnabled1->slotSet(0.0); + pButtonSyncEnabled1->set(1.0); + pButtonSyncEnabled1->set(0.0); ProcessBuffer(); @@ -1003,7 +1003,7 @@ TEST_F(EngineSyncTest, LoadTrackInitializesMaster) { auto pButtonSyncEnabled1 = std::make_unique(m_sGroup1, "sync_enabled"); - pButtonSyncEnabled1->slotSet(1.0); + pButtonSyncEnabled1->set(1.0); // No master because this deck has no track. EXPECT_EQ(NULL, m_pEngineSync->getMaster()); @@ -1030,7 +1030,7 @@ TEST_F(EngineSyncTest, LoadTrackInitializesMaster) { auto pButtonSyncEnabled2 = std::make_unique(m_sGroup2, "sync_enabled"); - pButtonSyncEnabled2->slotSet(1.0); + pButtonSyncEnabled2->set(1.0); m_pMixerDeck1->loadFakeTrack(false, 128.0); @@ -1139,8 +1139,8 @@ TEST_F(EngineSyncTest, LoadTrackResetTempoOption) { ->set(getRateSliderValue(1.5)); ControlObject::getControl(ConfigKey(m_sGroup2, "rate")) ->set(getRateSliderValue(1.5)); - pButtonSyncEnabled1->slotSet(0.0); - pButtonSyncEnabled2->slotSet(0.0); + pButtonSyncEnabled1->set(0.0); + pButtonSyncEnabled2->set(0.0); track1 = m_pMixerDeck1->loadFakeTrack(false, 140.0); ControlObject::getControl(ConfigKey(m_sGroup1, "play"))->set(1.0); track2 = m_pMixerDeck2->loadFakeTrack(false, 128.0); @@ -1162,7 +1162,7 @@ TEST_F(EngineSyncTest, EnableOneDeckSliderUpdates) { ->set(getRateSliderValue(1.0)); // Set the deck to sync enabled. - pButtonSyncEnabled1->slotSet(1.0); + pButtonSyncEnabled1->set(1.0); ProcessBuffer(); // Group 1 should now be master (only one sync deck). @@ -1433,7 +1433,7 @@ TEST_F(EngineSyncTest, ExplicitMasterPostProcessed) { // channel gets post-processed. auto pButtonMasterSync1 = std::make_unique(m_sGroup1, "sync_mode"); - pButtonMasterSync1->slotSet(SYNC_MASTER_EXPLICIT); + pButtonMasterSync1->set(SYNC_MASTER_EXPLICIT); mixxx::BeatsPointer pBeats1 = BeatFactory::makeBeatGrid( m_pTrack1->getSampleRate(), mixxx::Bpm(160), mixxx::audio::kStartFramePos); m_pTrack1->trySetBeats(pBeats1); @@ -1835,10 +1835,10 @@ TEST_F(EngineSyncTest, HalfDoubleThenPlay) { auto pButtonSyncEnabled1 = std::make_unique(m_sGroup1, "sync_enabled"); - pButtonSyncEnabled1->slotSet(1.0); + pButtonSyncEnabled1->set(1.0); auto pButtonSyncEnabled2 = std::make_unique(m_sGroup2, "sync_enabled"); - pButtonSyncEnabled2->slotSet(1.0); + pButtonSyncEnabled2->set(1.0); ControlObject::getControl(ConfigKey(m_sGroup1, "quantize"))->set(1.0); ControlObject::getControl(ConfigKey(m_sGroup2, "quantize"))->set(1.0); @@ -1896,11 +1896,11 @@ TEST_F(EngineSyncTest, HalfDoubleThenPlay) { // Sync only cares about which deck plays first now, enable order is irrelevant. ControlObject::getControl(ConfigKey(m_sGroup1, "play"))->set(0.0); ControlObject::getControl(ConfigKey(m_sGroup2, "play"))->set(0.0); - pButtonSyncEnabled1->slotSet(0.0); - pButtonSyncEnabled2->slotSet(0.0); + pButtonSyncEnabled1->set(0.0); + pButtonSyncEnabled2->set(0.0); ProcessBuffer(); - pButtonSyncEnabled2->slotSet(1.0); - pButtonSyncEnabled1->slotSet(1.0); + pButtonSyncEnabled2->set(1.0); + pButtonSyncEnabled1->set(1.0); EXPECT_DOUBLE_EQ(0.5, m_pChannel1->getEngineBuffer() ->m_pSyncControl->m_masterBpmAdjustFactor); diff --git a/src/test/hotcuecontrol_test.cpp b/src/test/hotcuecontrol_test.cpp index d92b3e966b5..6f81b22ff4c 100644 --- a/src/test/hotcuecontrol_test.cpp +++ b/src/test/hotcuecontrol_test.cpp @@ -131,38 +131,38 @@ TEST_F(HotcueControlTest, DefautltControlValues) { TEST_F(HotcueControlTest, NoTrackLoaded) { TrackPointer pTrack = createTestTrack(); - m_pHotcue1Set->slotSet(1); - m_pHotcue1Set->slotSet(0); + m_pHotcue1Set->set(1); + m_pHotcue1Set->set(0); EXPECT_DOUBLE_EQ(static_cast(HotcueControl::Status::Empty), m_pHotcue1Enabled->get()); EXPECT_DOUBLE_EQ(Cue::kNoPosition, m_pHotcue1Position->get()); EXPECT_DOUBLE_EQ(Cue::kNoPosition, m_pHotcue1EndPosition->get()); - m_pHotcue1SetCue->slotSet(1); - m_pHotcue1SetCue->slotSet(0); + m_pHotcue1SetCue->set(1); + m_pHotcue1SetCue->set(0); EXPECT_DOUBLE_EQ(static_cast(HotcueControl::Status::Empty), m_pHotcue1Enabled->get()); EXPECT_DOUBLE_EQ(Cue::kNoPosition, m_pHotcue1Position->get()); EXPECT_DOUBLE_EQ(Cue::kNoPosition, m_pHotcue1EndPosition->get()); - m_pHotcue1SetLoop->slotSet(1); - m_pHotcue1SetLoop->slotSet(0); + m_pHotcue1SetLoop->set(1); + m_pHotcue1SetLoop->set(0); EXPECT_DOUBLE_EQ(static_cast(HotcueControl::Status::Empty), m_pHotcue1Enabled->get()); EXPECT_DOUBLE_EQ(Cue::kNoPosition, m_pHotcue1Position->get()); EXPECT_DOUBLE_EQ(Cue::kNoPosition, m_pHotcue1EndPosition->get()); - m_pHotcue1Activate->slotSet(1); - m_pHotcue1Activate->slotSet(0); + m_pHotcue1Activate->set(1); + m_pHotcue1Activate->set(0); EXPECT_DOUBLE_EQ(static_cast(HotcueControl::Status::Empty), m_pHotcue1Enabled->get()); EXPECT_DOUBLE_EQ(Cue::kNoPosition, m_pHotcue1Position->get()); EXPECT_DOUBLE_EQ(Cue::kNoPosition, m_pHotcue1EndPosition->get()); - m_pHotcue1ActivateCue->slotSet(1); - m_pHotcue1ActivateCue->slotSet(0); + m_pHotcue1ActivateCue->set(1); + m_pHotcue1ActivateCue->set(0); EXPECT_DOUBLE_EQ(static_cast(HotcueControl::Status::Empty), m_pHotcue1Enabled->get()); EXPECT_DOUBLE_EQ(Cue::kNoPosition, m_pHotcue1Position->get()); EXPECT_DOUBLE_EQ(Cue::kNoPosition, m_pHotcue1EndPosition->get()); - m_pHotcue1ActivateLoop->slotSet(1); - m_pHotcue1ActivateLoop->slotSet(0); + m_pHotcue1ActivateLoop->set(1); + m_pHotcue1ActivateLoop->set(0); EXPECT_DOUBLE_EQ(static_cast(HotcueControl::Status::Empty), m_pHotcue1Enabled->get()); EXPECT_DOUBLE_EQ(Cue::kNoPosition, m_pHotcue1Position->get()); EXPECT_DOUBLE_EQ(Cue::kNoPosition, m_pHotcue1EndPosition->get()); @@ -175,12 +175,12 @@ TEST_F(HotcueControlTest, SetCueAuto) { EXPECT_DOUBLE_EQ(Cue::kNoPosition, m_pHotcue1Position->get()); EXPECT_DOUBLE_EQ(Cue::kNoPosition, m_pHotcue1EndPosition->get()); - m_pQuantizeEnabled->slotSet(0); + m_pQuantizeEnabled->set(0); setCurrentSamplePosition(100); ProcessBuffer(); - m_pHotcue1Set->slotSet(1); - m_pHotcue1Set->slotSet(0); + m_pHotcue1Set->set(1); + m_pHotcue1Set->set(0); EXPECT_DOUBLE_EQ(static_cast(HotcueControl::Status::Set), m_pHotcue1Enabled->get()); EXPECT_DOUBLE_EQ(100, m_pHotcue1Position->get()); EXPECT_DOUBLE_EQ(Cue::kNoPosition, m_pHotcue1EndPosition->get()); @@ -193,11 +193,11 @@ TEST_F(HotcueControlTest, SetCueManual) { EXPECT_DOUBLE_EQ(Cue::kNoPosition, m_pHotcue1Position->get()); EXPECT_DOUBLE_EQ(Cue::kNoPosition, m_pHotcue1EndPosition->get()); - m_pQuantizeEnabled->slotSet(0); + m_pQuantizeEnabled->set(0); setCurrentSamplePosition(100); - m_pHotcue1SetCue->slotSet(1); - m_pHotcue1SetCue->slotSet(0); + m_pHotcue1SetCue->set(1); + m_pHotcue1SetCue->set(0); EXPECT_DOUBLE_EQ(static_cast(HotcueControl::Status::Set), m_pHotcue1Enabled->get()); EXPECT_DOUBLE_EQ(100, m_pHotcue1Position->get()); EXPECT_DOUBLE_EQ(Cue::kNoPosition, m_pHotcue1EndPosition->get()); @@ -212,8 +212,8 @@ TEST_F(HotcueControlTest, SetLoopAuto) { m_pChannel1->getEngineBuffer()->setLoop(100, 200, true); - m_pHotcue1Set->slotSet(1); - m_pHotcue1Set->slotSet(0); + m_pHotcue1Set->set(1); + m_pHotcue1Set->set(0); EXPECT_DOUBLE_EQ(static_cast(HotcueControl::Status::Active), m_pHotcue1Enabled->get()); EXPECT_DOUBLE_EQ(100, m_pHotcue1Position->get()); EXPECT_DOUBLE_EQ(200, m_pHotcue1EndPosition->get()); @@ -228,8 +228,8 @@ TEST_F(HotcueControlTest, SetLoopManualWithLoop) { m_pChannel1->getEngineBuffer()->setLoop(100, 200, true); - m_pHotcue1SetLoop->slotSet(1); - m_pHotcue1SetLoop->slotSet(0); + m_pHotcue1SetLoop->set(1); + m_pHotcue1SetLoop->set(0); EXPECT_DOUBLE_EQ(static_cast(HotcueControl::Status::Active), m_pHotcue1Enabled->get()); EXPECT_DOUBLE_EQ(100, m_pHotcue1Position->get()); EXPECT_DOUBLE_EQ(200, m_pHotcue1EndPosition->get()); @@ -240,7 +240,7 @@ TEST_F(HotcueControlTest, SetLoopManualWithoutLoop) { TrackPointer pTrack = loadTestTrackWithBpm(120.0); const double beatLengthSamples = getBeatLengthSamples(pTrack); - m_pBeatloopSize->slotSet(4); + m_pBeatloopSize->set(4); const double beatloopLengthSamples = m_pBeatloopSize->get() * getBeatLengthSamples(pTrack); setCurrentSamplePosition(8 * beatLengthSamples); @@ -250,8 +250,8 @@ TEST_F(HotcueControlTest, SetLoopManualWithoutLoop) { EXPECT_DOUBLE_EQ(Cue::kNoPosition, m_pHotcue1Position->get()); EXPECT_DOUBLE_EQ(Cue::kNoPosition, m_pHotcue1EndPosition->get()); - m_pHotcue1SetLoop->slotSet(1); - m_pHotcue1SetLoop->slotSet(0); + m_pHotcue1SetLoop->set(1); + m_pHotcue1SetLoop->set(0); EXPECT_DOUBLE_EQ(static_cast(HotcueControl::Status::Active), m_pHotcue1Enabled->get()); EXPECT_DOUBLE_EQ(currentSamplePosition(), m_pHotcue1Position->get()); EXPECT_DOUBLE_EQ(currentSamplePosition() + beatloopLengthSamples, m_pHotcue1EndPosition->get()); @@ -264,8 +264,8 @@ TEST_F(HotcueControlTest, SetLoopManualWithoutLoopOrBeats) { EXPECT_DOUBLE_EQ(Cue::kNoPosition, m_pHotcue1Position->get()); EXPECT_DOUBLE_EQ(Cue::kNoPosition, m_pHotcue1EndPosition->get()); - m_pHotcue1SetLoop->slotSet(1); - m_pHotcue1SetLoop->slotSet(0); + m_pHotcue1SetLoop->set(1); + m_pHotcue1SetLoop->set(0); EXPECT_DOUBLE_EQ(static_cast(HotcueControl::Status::Empty), m_pHotcue1Enabled->get()); EXPECT_DOUBLE_EQ(Cue::kNoPosition, m_pHotcue1Position->get()); EXPECT_DOUBLE_EQ(Cue::kNoPosition, m_pHotcue1EndPosition->get()); @@ -286,8 +286,8 @@ TEST_F(HotcueControlTest, CueGoto) { ProcessBuffer(); EXPECT_DOUBLE_EQ(cuePositionSamples, currentSamplePosition()); - m_pHotcue1SetCue->slotSet(1); - m_pHotcue1SetCue->slotSet(0); + m_pHotcue1SetCue->set(1); + m_pHotcue1SetCue->set(0); EXPECT_DOUBLE_EQ(static_cast(HotcueControl::Status::Set), m_pHotcue1Enabled->get()); EXPECT_DOUBLE_EQ(cuePositionSamples, m_pHotcue1Position->get()); EXPECT_DOUBLE_EQ(Cue::kNoPosition, m_pHotcue1EndPosition->get()); @@ -297,8 +297,8 @@ TEST_F(HotcueControlTest, CueGoto) { ProcessBuffer(); EXPECT_DOUBLE_EQ(0, currentSamplePosition()); - m_pHotcue1Goto->slotSet(1); - m_pHotcue1Goto->slotSet(0); + m_pHotcue1Goto->set(1); + m_pHotcue1Goto->set(0); ProcessBuffer(); EXPECT_DOUBLE_EQ(cuePositionSamples, currentSamplePosition()); @@ -323,8 +323,8 @@ TEST_F(HotcueControlTest, CueGotoAndPlay) { ProcessBuffer(); EXPECT_DOUBLE_EQ(cuePositionSamples, currentSamplePosition()); - m_pHotcue1SetCue->slotSet(1); - m_pHotcue1SetCue->slotSet(0); + m_pHotcue1SetCue->set(1); + m_pHotcue1SetCue->set(0); EXPECT_DOUBLE_EQ(static_cast(HotcueControl::Status::Set), m_pHotcue1Enabled->get()); EXPECT_DOUBLE_EQ(cuePositionSamples, m_pHotcue1Position->get()); EXPECT_DOUBLE_EQ(Cue::kNoPosition, m_pHotcue1EndPosition->get()); @@ -334,8 +334,8 @@ TEST_F(HotcueControlTest, CueGotoAndPlay) { ProcessBuffer(); EXPECT_DOUBLE_EQ(0, currentSamplePosition()); - m_pHotcue1GotoAndPlay->slotSet(1); - m_pHotcue1GotoAndPlay->slotSet(0); + m_pHotcue1GotoAndPlay->set(1); + m_pHotcue1GotoAndPlay->set(0); ProcessBuffer(); EXPECT_LE(cuePositionSamples, currentSamplePosition()); @@ -355,7 +355,7 @@ TEST_F(HotcueControlTest, CueGotoAndLoop) { const double beatLengthSamples = getBeatLengthSamples(pTrack); const double cuePositionSamples = 8 * beatLengthSamples; - m_pBeatloopSize->slotSet(4); + m_pBeatloopSize->set(4); const double beatloopLengthSamples = m_pBeatloopSize->get() * getBeatLengthSamples(pTrack); // Seek to cue Position (8th beat) @@ -363,8 +363,8 @@ TEST_F(HotcueControlTest, CueGotoAndLoop) { ProcessBuffer(); EXPECT_DOUBLE_EQ(cuePositionSamples, currentSamplePosition()); - m_pHotcue1SetCue->slotSet(1); - m_pHotcue1SetCue->slotSet(0); + m_pHotcue1SetCue->set(1); + m_pHotcue1SetCue->set(0); EXPECT_DOUBLE_EQ(static_cast(HotcueControl::Status::Set), m_pHotcue1Enabled->get()); EXPECT_DOUBLE_EQ(cuePositionSamples, m_pHotcue1Position->get()); EXPECT_DOUBLE_EQ(Cue::kNoPosition, m_pHotcue1EndPosition->get()); @@ -374,8 +374,8 @@ TEST_F(HotcueControlTest, CueGotoAndLoop) { ProcessBuffer(); EXPECT_DOUBLE_EQ(0, currentSamplePosition()); - m_pHotcue1GotoAndLoop->slotSet(1); - m_pHotcue1GotoAndLoop->slotSet(0); + m_pHotcue1GotoAndLoop->set(1); + m_pHotcue1GotoAndLoop->set(0); ProcessBuffer(); EXPECT_LE(cuePositionSamples, currentSamplePosition()); @@ -392,7 +392,7 @@ TEST_F(HotcueControlTest, SavedLoopGoto) { // Setup fake track with 120 bpm and calculate loop size TrackPointer pTrack = loadTestTrackWithBpm(120.0); - m_pBeatloopSize->slotSet(4); + m_pBeatloopSize->set(4); const double beatLengthSamples = getBeatLengthSamples(pTrack); const double loopLengthSamples = m_pBeatloopSize->get() * beatLengthSamples; const double cuePositionSamples = 8 * beatLengthSamples; @@ -407,10 +407,10 @@ TEST_F(HotcueControlTest, SavedLoopGoto) { EXPECT_DOUBLE_EQ(cuePositionSamples, currentSamplePosition()); // Set a beatloop this position - m_pBeatloopActivate->slotSet(1); - m_pBeatloopActivate->slotSet(0); - m_pHotcue1SetLoop->slotSet(1); - m_pHotcue1SetLoop->slotSet(0); + m_pBeatloopActivate->set(1); + m_pBeatloopActivate->set(0); + m_pHotcue1SetLoop->set(1); + m_pHotcue1SetLoop->set(0); EXPECT_DOUBLE_EQ(1.0, m_pLoopEnabled->get()); // Save loop to hotcue slot 1 @@ -419,7 +419,7 @@ TEST_F(HotcueControlTest, SavedLoopGoto) { EXPECT_DOUBLE_EQ(cuePositionSamples + loopLengthSamples, m_pHotcue1EndPosition->get()); // Disable loop - m_pLoopEnabled->slotSet(0); + m_pLoopEnabled->set(0); EXPECT_DOUBLE_EQ(0.0, m_pLoopEnabled->get()); EXPECT_DOUBLE_EQ(static_cast(HotcueControl::Status::Set), m_pHotcue1Enabled->get()); @@ -428,8 +428,8 @@ TEST_F(HotcueControlTest, SavedLoopGoto) { ProcessBuffer(); EXPECT_DOUBLE_EQ(0, currentSamplePosition()); - m_pHotcue1Goto->slotSet(1); - m_pHotcue1Goto->slotSet(0); + m_pHotcue1Goto->set(1); + m_pHotcue1Goto->set(0); ProcessBuffer(); EXPECT_DOUBLE_EQ(cuePositionSamples, currentSamplePosition()); @@ -443,7 +443,7 @@ TEST_F(HotcueControlTest, SavedLoopGotoAndPlay) { // Setup fake track with 120 bpm and calculate loop size TrackPointer pTrack = loadTestTrackWithBpm(120.0); - m_pBeatloopSize->slotSet(4); + m_pBeatloopSize->set(4); const double beatLengthSamples = getBeatLengthSamples(pTrack); const double loopLengthSamples = m_pBeatloopSize->get() * beatLengthSamples; const double cuePositionSamples = 8 * beatLengthSamples; @@ -458,10 +458,10 @@ TEST_F(HotcueControlTest, SavedLoopGotoAndPlay) { EXPECT_DOUBLE_EQ(cuePositionSamples, currentSamplePosition()); // Set a beatloop this position - m_pBeatloopActivate->slotSet(1); - m_pBeatloopActivate->slotSet(0); - m_pHotcue1SetLoop->slotSet(1); - m_pHotcue1SetLoop->slotSet(0); + m_pBeatloopActivate->set(1); + m_pBeatloopActivate->set(0); + m_pHotcue1SetLoop->set(1); + m_pHotcue1SetLoop->set(0); EXPECT_DOUBLE_EQ(1.0, m_pLoopEnabled->get()); // Save loop to hotcue slot 1 @@ -470,7 +470,7 @@ TEST_F(HotcueControlTest, SavedLoopGotoAndPlay) { EXPECT_DOUBLE_EQ(cuePositionSamples + loopLengthSamples, m_pHotcue1EndPosition->get()); // Disable loop - m_pLoopEnabled->slotSet(0); + m_pLoopEnabled->set(0); EXPECT_DOUBLE_EQ(0.0, m_pLoopEnabled->get()); EXPECT_DOUBLE_EQ(static_cast(HotcueControl::Status::Set), m_pHotcue1Enabled->get()); @@ -479,8 +479,8 @@ TEST_F(HotcueControlTest, SavedLoopGotoAndPlay) { ProcessBuffer(); EXPECT_DOUBLE_EQ(0, currentSamplePosition()); - m_pHotcue1GotoAndPlay->slotSet(1); - m_pHotcue1GotoAndPlay->slotSet(0); + m_pHotcue1GotoAndPlay->set(1); + m_pHotcue1GotoAndPlay->set(0); ProcessBuffer(); EXPECT_LE(cuePositionSamples, currentSamplePosition()); @@ -494,7 +494,7 @@ TEST_F(HotcueControlTest, SavedLoopGotoAndLoop) { // Setup fake track with 120 bpm and calculate loop size TrackPointer pTrack = loadTestTrackWithBpm(120.0); - m_pBeatloopSize->slotSet(4); + m_pBeatloopSize->set(4); const double beatLengthSamples = getBeatLengthSamples(pTrack); const double loopLengthSamples = m_pBeatloopSize->get() * beatLengthSamples; const double cuePositionSamples = 8 * beatLengthSamples; @@ -509,10 +509,10 @@ TEST_F(HotcueControlTest, SavedLoopGotoAndLoop) { EXPECT_DOUBLE_EQ(cuePositionSamples, currentSamplePosition()); // Set a beatloop this position - m_pBeatloopActivate->slotSet(1); - m_pBeatloopActivate->slotSet(0); - m_pHotcue1SetLoop->slotSet(1); - m_pHotcue1SetLoop->slotSet(0); + m_pBeatloopActivate->set(1); + m_pBeatloopActivate->set(0); + m_pHotcue1SetLoop->set(1); + m_pHotcue1SetLoop->set(0); EXPECT_DOUBLE_EQ(1.0, m_pLoopEnabled->get()); // Save loop to hotcue slot 1 @@ -521,7 +521,7 @@ TEST_F(HotcueControlTest, SavedLoopGotoAndLoop) { EXPECT_DOUBLE_EQ(cuePositionSamples + loopLengthSamples, m_pHotcue1EndPosition->get()); // Disable loop - m_pLoopEnabled->slotSet(0); + m_pLoopEnabled->set(0); EXPECT_DOUBLE_EQ(0.0, m_pLoopEnabled->get()); EXPECT_DOUBLE_EQ(static_cast(HotcueControl::Status::Set), m_pHotcue1Enabled->get()); @@ -530,8 +530,8 @@ TEST_F(HotcueControlTest, SavedLoopGotoAndLoop) { ProcessBuffer(); EXPECT_DOUBLE_EQ(0, currentSamplePosition()); - m_pHotcue1GotoAndLoop->slotSet(1); - m_pHotcue1GotoAndLoop->slotSet(0); + m_pHotcue1GotoAndLoop->set(1); + m_pHotcue1GotoAndLoop->set(0); ProcessBuffer(); EXPECT_LE(cuePositionSamples, currentSamplePosition()); @@ -552,15 +552,15 @@ TEST_F(HotcueControlTest, SavedLoopStatus) { m_pChannel1->getEngineBuffer()->setLoop(100, 200, true); - m_pHotcue1SetLoop->slotSet(1); - m_pHotcue1SetLoop->slotSet(0); + m_pHotcue1SetLoop->set(1); + m_pHotcue1SetLoop->set(0); EXPECT_DOUBLE_EQ(1.0, m_pLoopEnabled->get()); EXPECT_DOUBLE_EQ(static_cast(HotcueControl::Status::Active), m_pHotcue1Enabled->get()); EXPECT_DOUBLE_EQ(100, m_pHotcue1Position->get()); EXPECT_DOUBLE_EQ(200, m_pHotcue1EndPosition->get()); // Disable Loop - m_pLoopEnabled->slotSet(0); + m_pLoopEnabled->set(0); EXPECT_DOUBLE_EQ(0.0, m_pLoopEnabled->get()); EXPECT_DOUBLE_EQ(static_cast(HotcueControl::Status::Set), m_pHotcue1Enabled->get()); @@ -568,15 +568,15 @@ TEST_F(HotcueControlTest, SavedLoopStatus) { EXPECT_DOUBLE_EQ(200, m_pHotcue1EndPosition->get()); // Re-Enable Loop - m_pLoopEnabled->slotSet(1); + m_pLoopEnabled->set(1); EXPECT_DOUBLE_EQ(1.0, m_pLoopEnabled->get()); EXPECT_DOUBLE_EQ(static_cast(HotcueControl::Status::Active), m_pHotcue1Enabled->get()); EXPECT_DOUBLE_EQ(100, m_pHotcue1Position->get()); EXPECT_DOUBLE_EQ(200, m_pHotcue1EndPosition->get()); - m_pHotcue1Clear->slotSet(1); - m_pHotcue1Clear->slotSet(0); + m_pHotcue1Clear->set(1); + m_pHotcue1Clear->set(0); EXPECT_DOUBLE_EQ(1.0, m_pLoopEnabled->get()); EXPECT_DOUBLE_EQ(static_cast(HotcueControl::Status::Empty), m_pHotcue1Enabled->get()); @@ -588,7 +588,7 @@ TEST_F(HotcueControlTest, SavedLoopScale) { // Setup fake track with 120 bpm and calculate loop size TrackPointer pTrack = loadTestTrackWithBpm(120.0); - m_pBeatloopSize->slotSet(4); + m_pBeatloopSize->set(4); const double beatLengthSamples = getBeatLengthSamples(pTrack); const double loopLengthSamples = m_pBeatloopSize->get() * beatLengthSamples; @@ -597,37 +597,37 @@ TEST_F(HotcueControlTest, SavedLoopScale) { EXPECT_DOUBLE_EQ(Cue::kNoPosition, m_pHotcue1EndPosition->get()); // Set a beatloop (4 beats) - m_pBeatloopActivate->slotSet(1); - m_pBeatloopActivate->slotSet(0); - m_pPlay->slotSet(1); + m_pBeatloopActivate->set(1); + m_pBeatloopActivate->set(0); + m_pPlay->set(1); ProcessBuffer(); // Save currently active loop to hotcue slot 1 - m_pHotcue1SetLoop->slotSet(1); - m_pHotcue1SetLoop->slotSet(0); + m_pHotcue1SetLoop->set(1); + m_pHotcue1SetLoop->set(0); EXPECT_DOUBLE_EQ(static_cast(HotcueControl::Status::Active), m_pHotcue1Enabled->get()); EXPECT_DOUBLE_EQ(0, m_pHotcue1Position->get()); EXPECT_DOUBLE_EQ(loopLengthSamples, m_pHotcue1EndPosition->get()); // Double loop size (4 => 8 beats) - m_pLoopDouble->slotSet(1); - m_pLoopDouble->slotSet(0); + m_pLoopDouble->set(1); + m_pLoopDouble->set(0); EXPECT_DOUBLE_EQ(0, m_pHotcue1Position->get()); EXPECT_DOUBLE_EQ(2 * loopLengthSamples, m_pHotcue1EndPosition->get()); // Halve loop size (8 => 4 beats) - m_pLoopHalve->slotSet(1); - m_pLoopHalve->slotSet(0); + m_pLoopHalve->set(1); + m_pLoopHalve->set(0); EXPECT_DOUBLE_EQ(0, m_pHotcue1Position->get()); EXPECT_DOUBLE_EQ(loopLengthSamples, m_pHotcue1EndPosition->get()); // Halve loop size (4 => 2 beats) - m_pLoopHalve->slotSet(1); - m_pLoopHalve->slotSet(0); + m_pLoopHalve->set(1); + m_pLoopHalve->set(0); EXPECT_DOUBLE_EQ(0, m_pHotcue1Position->get()); EXPECT_DOUBLE_EQ(loopLengthSamples / 2, m_pHotcue1EndPosition->get()); - m_pPlay->slotSet(0); + m_pPlay->set(0); } TEST_F(HotcueControlTest, SavedLoopMove) { @@ -635,7 +635,7 @@ TEST_F(HotcueControlTest, SavedLoopMove) { TrackPointer pTrack = loadTestTrackWithBpm(120.0); constexpr double loopSize = 4; - m_pBeatloopSize->slotSet(loopSize); + m_pBeatloopSize->set(loopSize); const double beatLengthSamples = getBeatLengthSamples(pTrack); const double loopLengthSamples = loopSize * beatLengthSamples; @@ -644,47 +644,47 @@ TEST_F(HotcueControlTest, SavedLoopMove) { EXPECT_DOUBLE_EQ(Cue::kNoPosition, m_pHotcue1EndPosition->get()); // Set a beatloop at position 0 - m_pBeatloopActivate->slotSet(1); - m_pBeatloopActivate->slotSet(0); - m_pPlay->slotSet(1); + m_pBeatloopActivate->set(1); + m_pBeatloopActivate->set(0); + m_pPlay->set(1); // Save currently active loop to hotcue slot 1 - m_pHotcue1SetLoop->slotSet(1); - m_pHotcue1SetLoop->slotSet(0); + m_pHotcue1SetLoop->set(1); + m_pHotcue1SetLoop->set(0); ProcessBuffer(); EXPECT_DOUBLE_EQ(static_cast(HotcueControl::Status::Active), m_pHotcue1Enabled->get()); EXPECT_DOUBLE_EQ(0, m_pHotcue1Position->get()); EXPECT_DOUBLE_EQ(loopLengthSamples, m_pHotcue1EndPosition->get()); // Move loop right (0 => 4 beats) - m_pLoopMove->slotSet(loopSize); + m_pLoopMove->set(loopSize); ProcessBuffer(); EXPECT_DOUBLE_EQ(static_cast(HotcueControl::Status::Active), m_pHotcue1Enabled->get()); EXPECT_DOUBLE_EQ(loopLengthSamples, m_pHotcue1Position->get()); EXPECT_DOUBLE_EQ(2 * loopLengthSamples, m_pHotcue1EndPosition->get()); // Move loop left (4 => 0 beats) - m_pLoopMove->slotSet(-loopSize); + m_pLoopMove->set(-loopSize); ProcessBuffer(); EXPECT_DOUBLE_EQ(static_cast(HotcueControl::Status::Active), m_pHotcue1Enabled->get()); EXPECT_DOUBLE_EQ(0, m_pHotcue1Position->get()); EXPECT_DOUBLE_EQ(loopLengthSamples, m_pHotcue1EndPosition->get()); // Move loop left (0 => -4 beats) - m_pLoopMove->slotSet(-loopSize); + m_pLoopMove->set(-loopSize); ProcessBuffer(); EXPECT_DOUBLE_EQ(static_cast(HotcueControl::Status::Active), m_pHotcue1Enabled->get()); EXPECT_DOUBLE_EQ(-loopLengthSamples, m_pHotcue1Position->get()); EXPECT_DOUBLE_EQ(0, m_pHotcue1EndPosition->get()); - m_pPlay->slotSet(0); + m_pPlay->set(0); } TEST_F(HotcueControlTest, SavedLoopNoScaleIfDisabled) { // Setup fake track with 120 bpm and calculate loop size TrackPointer pTrack = loadTestTrackWithBpm(120.0); - m_pBeatloopSize->slotSet(4); + m_pBeatloopSize->set(4); const double beatLengthSamples = getBeatLengthSamples(pTrack); const double loopLengthSamples = m_pBeatloopSize->get() * beatLengthSamples; @@ -693,41 +693,41 @@ TEST_F(HotcueControlTest, SavedLoopNoScaleIfDisabled) { EXPECT_DOUBLE_EQ(Cue::kNoPosition, m_pHotcue1EndPosition->get()); // Set a beatloop (4 beats) - m_pBeatloopActivate->slotSet(1); - m_pBeatloopActivate->slotSet(0); - m_pPlay->slotSet(1); + m_pBeatloopActivate->set(1); + m_pBeatloopActivate->set(0); + m_pPlay->set(1); ProcessBuffer(); // Save currently active loop to hotcue slot 1 - m_pHotcue1SetLoop->slotSet(1); - m_pHotcue1SetLoop->slotSet(0); + m_pHotcue1SetLoop->set(1); + m_pHotcue1SetLoop->set(0); EXPECT_DOUBLE_EQ(static_cast(HotcueControl::Status::Active), m_pHotcue1Enabled->get()); EXPECT_DOUBLE_EQ(0, m_pHotcue1Position->get()); EXPECT_DOUBLE_EQ(loopLengthSamples, m_pHotcue1EndPosition->get()); // Disable loop - m_pLoopEnabled->slotSet(0); + m_pLoopEnabled->set(0); EXPECT_DOUBLE_EQ(static_cast(HotcueControl::Status::Set), m_pHotcue1Enabled->get()); // Double loop size (4 => 8 beats) while saved loop is disabled - m_pLoopDouble->slotSet(1); - m_pLoopDouble->slotSet(0); + m_pLoopDouble->set(1); + m_pLoopDouble->set(0); EXPECT_DOUBLE_EQ(0, m_pHotcue1Position->get()); EXPECT_DOUBLE_EQ(loopLengthSamples, m_pHotcue1EndPosition->get()); // Halve loop size (8 => 4 beats) while saved loop is disabled - m_pLoopHalve->slotSet(1); - m_pLoopHalve->slotSet(0); + m_pLoopHalve->set(1); + m_pLoopHalve->set(0); EXPECT_DOUBLE_EQ(0, m_pHotcue1Position->get()); EXPECT_DOUBLE_EQ(loopLengthSamples, m_pHotcue1EndPosition->get()); // Halve loop size (4 => 2 beats) while saved loop is disabled - m_pLoopHalve->slotSet(1); - m_pLoopHalve->slotSet(0); + m_pLoopHalve->set(1); + m_pLoopHalve->set(0); EXPECT_DOUBLE_EQ(0, m_pHotcue1Position->get()); EXPECT_DOUBLE_EQ(loopLengthSamples, m_pHotcue1EndPosition->get()); - m_pPlay->slotSet(0); + m_pPlay->set(0); } TEST_F(HotcueControlTest, SavedLoopNoMoveIfDisabled) { @@ -735,7 +735,7 @@ TEST_F(HotcueControlTest, SavedLoopNoMoveIfDisabled) { TrackPointer pTrack = loadTestTrackWithBpm(120.0); constexpr double loopSize = 4; - m_pBeatloopSize->slotSet(loopSize); + m_pBeatloopSize->set(loopSize); const double beatLengthSamples = getBeatLengthSamples(pTrack); const double loopLengthSamples = loopSize * beatLengthSamples; @@ -744,45 +744,45 @@ TEST_F(HotcueControlTest, SavedLoopNoMoveIfDisabled) { EXPECT_DOUBLE_EQ(Cue::kNoPosition, m_pHotcue1EndPosition->get()); // Set a beatloop at position 0 - m_pBeatloopActivate->slotSet(1); - m_pBeatloopActivate->slotSet(0); - m_pPlay->slotSet(1); + m_pBeatloopActivate->set(1); + m_pBeatloopActivate->set(0); + m_pPlay->set(1); // Save currently active loop to hotcue slot 1 - m_pHotcue1SetLoop->slotSet(1); - m_pHotcue1SetLoop->slotSet(0); + m_pHotcue1SetLoop->set(1); + m_pHotcue1SetLoop->set(0); EXPECT_DOUBLE_EQ(static_cast(HotcueControl::Status::Active), m_pHotcue1Enabled->get()); EXPECT_DOUBLE_EQ(0, m_pHotcue1Position->get()); EXPECT_DOUBLE_EQ(loopLengthSamples, m_pHotcue1EndPosition->get()); // Disable Loop - m_pLoopEnabled->slotSet(0); + m_pLoopEnabled->set(0); ProcessBuffer(); EXPECT_DOUBLE_EQ(static_cast(HotcueControl::Status::Set), m_pHotcue1Enabled->get()); // Move loop right (0 => 4 beats) while saved loop is disabled - m_pLoopMove->slotSet(loopSize); + m_pLoopMove->set(loopSize); EXPECT_DOUBLE_EQ(0, m_pHotcue1Position->get()); EXPECT_DOUBLE_EQ(loopLengthSamples, m_pHotcue1EndPosition->get()); // Move loop left (4 => 0 beats) while saved loop is disabled - m_pLoopMove->slotSet(-loopSize); + m_pLoopMove->set(-loopSize); EXPECT_DOUBLE_EQ(0, m_pHotcue1Position->get()); EXPECT_DOUBLE_EQ(loopLengthSamples, m_pHotcue1EndPosition->get()); // Move loop left (0 => -4 beats) while saved loop is disabled - m_pLoopMove->slotSet(-loopSize); + m_pLoopMove->set(-loopSize); EXPECT_DOUBLE_EQ(0, m_pHotcue1Position->get()); EXPECT_DOUBLE_EQ(loopLengthSamples, m_pHotcue1EndPosition->get()); - m_pPlay->slotSet(0); + m_pPlay->set(0); } TEST_F(HotcueControlTest, SavedLoopReset) { // Setup fake track with 120 bpm and calculate loop size TrackPointer pTrack = loadTestTrackWithBpm(120.0); - m_pBeatloopSize->slotSet(4); + m_pBeatloopSize->set(4); const double beatLengthSamples = getBeatLengthSamples(pTrack); const double loopLengthSamples = m_pBeatloopSize->get() * beatLengthSamples; @@ -791,21 +791,21 @@ TEST_F(HotcueControlTest, SavedLoopReset) { EXPECT_DOUBLE_EQ(Cue::kNoPosition, m_pHotcue1EndPosition->get()); // Set a beatloop - m_pBeatloopActivate->slotSet(1); - m_pBeatloopActivate->slotSet(0); + m_pBeatloopActivate->set(1); + m_pBeatloopActivate->set(0); ProcessBuffer(); // Save currently active loop to hotcue slot 1 - m_pHotcue1SetLoop->slotSet(1); - m_pHotcue1SetLoop->slotSet(0); + m_pHotcue1SetLoop->set(1); + m_pHotcue1SetLoop->set(0); EXPECT_DOUBLE_EQ(static_cast(HotcueControl::Status::Active), m_pHotcue1Enabled->get()); EXPECT_DOUBLE_EQ(0, m_pHotcue1Position->get()); EXPECT_DOUBLE_EQ(loopLengthSamples, m_pHotcue1EndPosition->get()); // Set a new beatloop setCurrentSamplePosition(loopLengthSamples); - m_pBeatloopActivate->slotSet(1); - m_pBeatloopActivate->slotSet(0); + m_pBeatloopActivate->set(1); + m_pBeatloopActivate->set(0); ProcessBuffer(); // Check if setting the new beatloop disabled the current saved loop @@ -823,16 +823,16 @@ TEST_F(HotcueControlTest, SavedLoopCueLoopWithExistingLoop) { m_pChannel1->getEngineBuffer()->setLoop(100, 200, true); - m_pHotcue1SetLoop->slotSet(1); - m_pHotcue1SetLoop->slotSet(0); + m_pHotcue1SetLoop->set(1); + m_pHotcue1SetLoop->set(0); EXPECT_DOUBLE_EQ(1.0, m_pLoopEnabled->get()); EXPECT_DOUBLE_EQ(static_cast(HotcueControl::Status::Active), m_pHotcue1Enabled->get()); EXPECT_DOUBLE_EQ(100, m_pHotcue1Position->get()); EXPECT_DOUBLE_EQ(200, m_pHotcue1EndPosition->get()); // Disable Loop - m_pHotcue1CueLoop->slotSet(1); - m_pHotcue1CueLoop->slotSet(0); + m_pHotcue1CueLoop->set(1); + m_pHotcue1CueLoop->set(0); EXPECT_DOUBLE_EQ(0.0, m_pLoopEnabled->get()); EXPECT_DOUBLE_EQ(static_cast(HotcueControl::Status::Set), m_pHotcue1Enabled->get()); @@ -840,8 +840,8 @@ TEST_F(HotcueControlTest, SavedLoopCueLoopWithExistingLoop) { EXPECT_DOUBLE_EQ(200, m_pHotcue1EndPosition->get()); // Re-Enable Loop - m_pHotcue1CueLoop->slotSet(1); - m_pHotcue1CueLoop->slotSet(0); + m_pHotcue1CueLoop->set(1); + m_pHotcue1CueLoop->set(0); EXPECT_DOUBLE_EQ(1.0, m_pLoopEnabled->get()); EXPECT_DOUBLE_EQ(static_cast(HotcueControl::Status::Active), m_pHotcue1Enabled->get()); @@ -857,8 +857,8 @@ TEST_F(HotcueControlTest, CueLoopWithoutHotcueSetsHotcue) { EXPECT_DOUBLE_EQ(Cue::kNoPosition, m_pHotcue1Position->get()); EXPECT_DOUBLE_EQ(Cue::kNoPosition, m_pHotcue1EndPosition->get()); - m_pHotcue1CueLoop->slotSet(1); - m_pHotcue1CueLoop->slotSet(0); + m_pHotcue1CueLoop->set(1); + m_pHotcue1CueLoop->set(0); EXPECT_DOUBLE_EQ(static_cast(HotcueControl::Status::Set), m_pHotcue1Enabled->get()); EXPECT_DOUBLE_EQ(0, m_pHotcue1Position->get()); @@ -870,24 +870,24 @@ TEST_F(HotcueControlTest, CueLoopWithSavedLoopToggles) { // Setup fake track with 120 bpm and calculate loop size TrackPointer pTrack = loadTestTrackWithBpm(120.0); - m_pHotcue1SetLoop->slotSet(1); - m_pHotcue1SetLoop->slotSet(0); + m_pHotcue1SetLoop->set(1); + m_pHotcue1SetLoop->set(0); EXPECT_DOUBLE_EQ(static_cast(HotcueControl::Status::Active), m_pHotcue1Enabled->get()); EXPECT_DOUBLE_EQ(0, m_pHotcue1Position->get()); EXPECT_NE(Cue::kNoPosition, m_pHotcue1EndPosition->get()); EXPECT_TRUE(m_pLoopEnabled->toBool()); - m_pHotcue1CueLoop->slotSet(1); - m_pHotcue1CueLoop->slotSet(0); + m_pHotcue1CueLoop->set(1); + m_pHotcue1CueLoop->set(0); EXPECT_DOUBLE_EQ(static_cast(HotcueControl::Status::Set), m_pHotcue1Enabled->get()); EXPECT_DOUBLE_EQ(0, m_pHotcue1Position->get()); EXPECT_NE(Cue::kNoPosition, m_pHotcue1EndPosition->get()); EXPECT_FALSE(m_pLoopEnabled->toBool()); - m_pHotcue1CueLoop->slotSet(1); - m_pHotcue1CueLoop->slotSet(0); + m_pHotcue1CueLoop->set(1); + m_pHotcue1CueLoop->set(0); EXPECT_DOUBLE_EQ(static_cast(HotcueControl::Status::Active), m_pHotcue1Enabled->get()); EXPECT_DOUBLE_EQ(0, m_pHotcue1Position->get()); @@ -902,8 +902,8 @@ TEST_F(HotcueControlTest, CueLoopWithoutLoopOrBeats) { EXPECT_DOUBLE_EQ(Cue::kNoPosition, m_pHotcue1Position->get()); EXPECT_DOUBLE_EQ(Cue::kNoPosition, m_pHotcue1EndPosition->get()); - m_pHotcue1CueLoop->slotSet(1); - m_pHotcue1CueLoop->slotSet(0); + m_pHotcue1CueLoop->set(1); + m_pHotcue1CueLoop->set(0); EXPECT_DOUBLE_EQ(static_cast(HotcueControl::Status::Set), m_pHotcue1Enabled->get()); EXPECT_DOUBLE_EQ(0, m_pHotcue1Position->get()); @@ -930,15 +930,15 @@ TEST_F(HotcueControlTest, SavedLoopToggleDoesNotSeek) { setCurrentSamplePosition(loopStartPositionSamples); ProcessBuffer(); - m_pPlay->slotSet(1); + m_pPlay->set(1); // Set a beatloop - m_pBeatloopActivate->slotSet(1); - m_pBeatloopActivate->slotSet(0); + m_pBeatloopActivate->set(1); + m_pBeatloopActivate->set(0); // Save currently active loop to hotcue slot 1 - m_pHotcue1SetLoop->slotSet(1); - m_pHotcue1SetLoop->slotSet(0); + m_pHotcue1SetLoop->set(1); + m_pHotcue1SetLoop->set(0); EXPECT_DOUBLE_EQ(static_cast(HotcueControl::Status::Active), m_pHotcue1Enabled->get()); EXPECT_DOUBLE_EQ(loopStartPositionSamples, m_pHotcue1Position->get()); EXPECT_DOUBLE_EQ(loopStartPositionSamples + loopLengthSamples, m_pHotcue1EndPosition->get()); @@ -953,8 +953,8 @@ TEST_F(HotcueControlTest, SavedLoopToggleDoesNotSeek) { EXPECT_DOUBLE_EQ(loopStartPositionSamples + loopLengthSamples, m_pHotcue1EndPosition->get()); // Re-Enable loop - m_pHotcue1Activate->slotSet(1); - m_pHotcue1Activate->slotSet(0); + m_pHotcue1Activate->set(1); + m_pHotcue1Activate->set(0); ProcessBuffer(); EXPECT_DOUBLE_EQ(static_cast(HotcueControl::Status::Active), m_pHotcue1Enabled->get()); EXPECT_DOUBLE_EQ(loopStartPositionSamples, m_pHotcue1Position->get()); @@ -964,8 +964,8 @@ TEST_F(HotcueControlTest, SavedLoopToggleDoesNotSeek) { EXPECT_NEAR(beforeLoopPositionSamples, currentSamplePosition(), 2048); // Disable loop - m_pHotcue1Activate->slotSet(1); - m_pHotcue1Activate->slotSet(0); + m_pHotcue1Activate->set(1); + m_pHotcue1Activate->set(0); ProcessBuffer(); EXPECT_DOUBLE_EQ(static_cast(HotcueControl::Status::Set), m_pHotcue1Enabled->get()); EXPECT_DOUBLE_EQ(loopStartPositionSamples, m_pHotcue1Position->get()); @@ -976,7 +976,7 @@ TEST_F(HotcueControlTest, SavedLoopActivate) { // Setup fake track with 120 bpm and calculate loop size TrackPointer pTrack = loadTestTrackWithBpm(120.0); - m_pBeatloopSize->slotSet(4); + m_pBeatloopSize->set(4); const double beatLengthSamples = getBeatLengthSamples(pTrack); const double loopLengthSamples = m_pBeatloopSize->get() * beatLengthSamples; @@ -993,14 +993,14 @@ TEST_F(HotcueControlTest, SavedLoopActivate) { ProcessBuffer(); // Set a beatloop - m_pBeatloopActivate->slotSet(1); - m_pBeatloopActivate->slotSet(0); + m_pBeatloopActivate->set(1); + m_pBeatloopActivate->set(0); m_pPlay->set(1); // Save currently active loop to hotcue slot 1 - m_pHotcue1Activate->slotSet(1); - m_pHotcue1Activate->slotSet(0); + m_pHotcue1Activate->set(1); + m_pHotcue1Activate->set(0); EXPECT_DOUBLE_EQ(static_cast(HotcueControl::Status::Active), m_pHotcue1Enabled->get()); EXPECT_DOUBLE_EQ(loopStartPositionSamples, m_pHotcue1Position->get()); EXPECT_DOUBLE_EQ(loopStartPositionSamples + loopLengthSamples, m_pHotcue1EndPosition->get()); @@ -1016,8 +1016,8 @@ TEST_F(HotcueControlTest, SavedLoopActivate) { EXPECT_DOUBLE_EQ(loopStartPositionSamples + loopLengthSamples, m_pHotcue1EndPosition->get()); // Activate saved loop (does not imply seeking to loop start) - m_pHotcue1Activate->slotSet(1); - m_pHotcue1Activate->slotSet(0); + m_pHotcue1Activate->set(1); + m_pHotcue1Activate->set(0); ProcessBuffer(); EXPECT_DOUBLE_EQ(static_cast(HotcueControl::Status::Active), m_pHotcue1Enabled->get()); EXPECT_DOUBLE_EQ(loopStartPositionSamples, m_pHotcue1Position->get()); @@ -1037,8 +1037,8 @@ TEST_F(HotcueControlTest, SavedLoopActivate) { // Activate saved loop (usually doesn't imply seeking to loop start, but in this case it does // because the play position is behind the loop end position) - m_pHotcue1Activate->slotSet(1); - m_pHotcue1Activate->slotSet(0); + m_pHotcue1Activate->set(1); + m_pHotcue1Activate->set(0); ProcessBuffer(); EXPECT_DOUBLE_EQ(static_cast(HotcueControl::Status::Active), m_pHotcue1Enabled->get()); EXPECT_DOUBLE_EQ(loopStartPositionSamples, m_pHotcue1Position->get()); @@ -1050,7 +1050,7 @@ TEST_F(HotcueControlTest, SavedLoopActivateWhilePlayingTogglesLoop) { // Setup fake track with 120 bpm and calculate loop size TrackPointer pTrack = loadTestTrackWithBpm(120.0); - m_pBeatloopSize->slotSet(4); + m_pBeatloopSize->set(4); const double beatLengthSamples = getBeatLengthSamples(pTrack); const double loopLengthSamples = m_pBeatloopSize->get() * beatLengthSamples; const double loopStartPosition = 8 * beatLengthSamples; @@ -1063,16 +1063,16 @@ TEST_F(HotcueControlTest, SavedLoopActivateWhilePlayingTogglesLoop) { // Set a beatloop setCurrentSamplePosition(loopStartPosition); ProcessBuffer(); - m_pBeatloopActivate->slotSet(1); - m_pBeatloopActivate->slotSet(0); + m_pBeatloopActivate->set(1); + m_pBeatloopActivate->set(0); - m_pQuantizeEnabled->slotSet(1); - m_pPlay->slotSet(1); + m_pQuantizeEnabled->set(1); + m_pPlay->set(1); ProcessBuffer(); // Save currently active loop to hotcue slot 1 - m_pHotcue1Activate->slotSet(1); - m_pHotcue1Activate->slotSet(0); + m_pHotcue1Activate->set(1); + m_pHotcue1Activate->set(0); EXPECT_DOUBLE_EQ(static_cast(HotcueControl::Status::Active), m_pHotcue1Enabled->get()); EXPECT_DOUBLE_EQ(loopStartPosition, m_pHotcue1Position->get()); EXPECT_DOUBLE_EQ(loopEndPosition, m_pHotcue1EndPosition->get()); @@ -1080,13 +1080,13 @@ TEST_F(HotcueControlTest, SavedLoopActivateWhilePlayingTogglesLoop) { EXPECT_DOUBLE_EQ(m_pHotcue1Position->get(), m_pLoopStartPosition->get()); EXPECT_DOUBLE_EQ(m_pHotcue1EndPosition->get(), m_pLoopEndPosition->get()); - m_pHotcue1Activate->slotSet(1); - m_pHotcue1Activate->slotSet(0); + m_pHotcue1Activate->set(1); + m_pHotcue1Activate->set(0); EXPECT_DOUBLE_EQ(static_cast(HotcueControl::Status::Set), m_pHotcue1Enabled->get()); EXPECT_DOUBLE_EQ(0.0, m_pLoopEnabled->get()); - m_pHotcue1Activate->slotSet(1); - m_pHotcue1Activate->slotSet(0); + m_pHotcue1Activate->set(1); + m_pHotcue1Activate->set(0); EXPECT_DOUBLE_EQ(static_cast(HotcueControl::Status::Active), m_pHotcue1Enabled->get()); EXPECT_DOUBLE_EQ(1.0, m_pLoopEnabled->get()); } @@ -1096,7 +1096,7 @@ TEST_F(HotcueControlTest, SavedLoopBeatLoopSizeRestore) { TrackPointer pTrack = loadTestTrackWithBpm(120.0); constexpr double savedLoopSize = 8; - m_pBeatloopSize->slotSet(savedLoopSize); + m_pBeatloopSize->set(savedLoopSize); const double beatLengthSamples = getBeatLengthSamples(pTrack); const double loopLengthSamples = m_pBeatloopSize->get() * beatLengthSamples; @@ -1105,30 +1105,30 @@ TEST_F(HotcueControlTest, SavedLoopBeatLoopSizeRestore) { EXPECT_DOUBLE_EQ(Cue::kNoPosition, m_pHotcue1EndPosition->get()); // Set a beatloop - m_pBeatloopActivate->slotSet(1); - m_pBeatloopActivate->slotSet(0); + m_pBeatloopActivate->set(1); + m_pBeatloopActivate->set(0); m_pPlay->set(1); // Save currently active loop to hotcue slot 1 - m_pHotcue1ActivateLoop->slotSet(1); - m_pHotcue1ActivateLoop->slotSet(0); + m_pHotcue1ActivateLoop->set(1); + m_pHotcue1ActivateLoop->set(0); EXPECT_DOUBLE_EQ(static_cast(HotcueControl::Status::Active), m_pHotcue1Enabled->get()); EXPECT_DOUBLE_EQ(0, m_pHotcue1Position->get()); EXPECT_DOUBLE_EQ(loopLengthSamples, m_pHotcue1EndPosition->get()); // Disable loop - m_pLoopEnabled->slotSet(0); + m_pLoopEnabled->set(0); EXPECT_DOUBLE_EQ(static_cast(HotcueControl::Status::Set), m_pHotcue1Enabled->get()); EXPECT_DOUBLE_EQ(0, m_pHotcue1Position->get()); EXPECT_DOUBLE_EQ(loopLengthSamples, m_pHotcue1EndPosition->get()); // Set new beatloop size - m_pBeatloopSize->slotSet(savedLoopSize / 2); + m_pBeatloopSize->set(savedLoopSize / 2); // Re-enabled saved loop - m_pHotcue1ActivateLoop->slotSet(1); - m_pHotcue1ActivateLoop->slotSet(0); + m_pHotcue1ActivateLoop->set(1); + m_pHotcue1ActivateLoop->set(0); EXPECT_DOUBLE_EQ(static_cast(HotcueControl::Status::Active), m_pHotcue1Enabled->get()); EXPECT_DOUBLE_EQ(0, m_pHotcue1Position->get()); EXPECT_DOUBLE_EQ(loopLengthSamples, m_pHotcue1EndPosition->get()); @@ -1142,7 +1142,7 @@ TEST_F(HotcueControlTest, SavedLoopBeatLoopSizeRestoreDoesNotJump) { TrackPointer pTrack = loadTestTrackWithBpm(120.0); constexpr double savedLoopSize = 4; - m_pBeatloopSize->slotSet(savedLoopSize); + m_pBeatloopSize->set(savedLoopSize); const double beatLengthSamples = getBeatLengthSamples(pTrack); const double loopLengthSamples = m_pBeatloopSize->get() * beatLengthSamples; const double cuePositionSamples = 8 * beatLengthSamples; @@ -1159,12 +1159,12 @@ TEST_F(HotcueControlTest, SavedLoopBeatLoopSizeRestoreDoesNotJump) { EXPECT_DOUBLE_EQ(cuePositionSamples, currentSamplePosition()); // Set a beatloop - m_pBeatloopActivate->slotSet(1); - m_pBeatloopActivate->slotSet(0); + m_pBeatloopActivate->set(1); + m_pBeatloopActivate->set(0); // Save currently active loop to hotcue slot 1 - m_pHotcue1SetLoop->slotSet(1); - m_pHotcue1SetLoop->slotSet(0); + m_pHotcue1SetLoop->set(1); + m_pHotcue1SetLoop->set(0); EXPECT_DOUBLE_EQ(static_cast(HotcueControl::Status::Active), m_pHotcue1Enabled->get()); EXPECT_DOUBLE_EQ(cuePositionSamples, m_pHotcue1Position->get()); EXPECT_DOUBLE_EQ(cuePositionSamples + loopLengthSamples, m_pHotcue1EndPosition->get()); @@ -1174,20 +1174,20 @@ TEST_F(HotcueControlTest, SavedLoopBeatLoopSizeRestoreDoesNotJump) { // Check 1: Play position before saved loop // Disable loop - m_pLoopEnabled->slotSet(0); + m_pLoopEnabled->set(0); EXPECT_DOUBLE_EQ(static_cast(HotcueControl::Status::Set), m_pHotcue1Enabled->get()); EXPECT_DOUBLE_EQ(cuePositionSamples, m_pHotcue1Position->get()); EXPECT_DOUBLE_EQ(cuePositionSamples + loopLengthSamples, m_pHotcue1EndPosition->get()); // Set new beatloop size - m_pBeatloopSize->slotSet(m_pBeatloopSize->get() / 2); + m_pBeatloopSize->set(m_pBeatloopSize->get() / 2); // Seek to position before saved loop setCurrentSamplePosition(beforeLoopPositionSamples); // Re-enable saved loop - m_pHotcue1Activate->slotSet(1); - m_pHotcue1Activate->slotSet(0); + m_pHotcue1Activate->set(1); + m_pHotcue1Activate->set(0); EXPECT_DOUBLE_EQ(static_cast(HotcueControl::Status::Active), m_pHotcue1Enabled->get()); EXPECT_DOUBLE_EQ(cuePositionSamples, m_pHotcue1Position->get()); EXPECT_DOUBLE_EQ(cuePositionSamples + loopLengthSamples, m_pHotcue1EndPosition->get()); @@ -1201,20 +1201,20 @@ TEST_F(HotcueControlTest, SavedLoopBeatLoopSizeRestoreDoesNotJump) { // Check 2: Play position after saved loop // Disable loop - m_pLoopEnabled->slotSet(0); + m_pLoopEnabled->set(0); EXPECT_DOUBLE_EQ(static_cast(HotcueControl::Status::Set), m_pHotcue1Enabled->get()); EXPECT_DOUBLE_EQ(cuePositionSamples, m_pHotcue1Position->get()); EXPECT_DOUBLE_EQ(cuePositionSamples + loopLengthSamples, m_pHotcue1EndPosition->get()); // Set new beatloop size - m_pBeatloopSize->slotSet(m_pBeatloopSize->get() / 2); + m_pBeatloopSize->set(m_pBeatloopSize->get() / 2); // Seek to position after saved loop setCurrentSamplePosition(afterLoopPositionSamples); // Re-enable saved loop - m_pHotcue1Activate->slotSet(1); - m_pHotcue1Activate->slotSet(0); + m_pHotcue1Activate->set(1); + m_pHotcue1Activate->set(0); EXPECT_DOUBLE_EQ(static_cast(HotcueControl::Status::Active), m_pHotcue1Enabled->get()); EXPECT_DOUBLE_EQ(cuePositionSamples, m_pHotcue1Position->get()); EXPECT_DOUBLE_EQ(cuePositionSamples + loopLengthSamples, m_pHotcue1EndPosition->get()); @@ -1236,13 +1236,13 @@ TEST_F(HotcueControlTest, SavedLoopUnloadTrackWhileActive) { EXPECT_DOUBLE_EQ(Cue::kNoPosition, m_pHotcue1EndPosition->get()); // Set a beatloop - m_pBeatloopActivate->slotSet(1); - m_pBeatloopActivate->slotSet(0); + m_pBeatloopActivate->set(1); + m_pBeatloopActivate->set(0); ProcessBuffer(); // Save currently active loop to hotcue slot 1 - m_pHotcue1SetLoop->slotSet(1); - m_pHotcue1SetLoop->slotSet(0); + m_pHotcue1SetLoop->set(1); + m_pHotcue1SetLoop->set(0); ProcessBuffer(); EXPECT_DOUBLE_EQ(static_cast(HotcueControl::Status::Active), m_pHotcue1Enabled->get()); EXPECT_NE(Cue::kNoPosition, m_pHotcue1Position->get()); @@ -1271,13 +1271,13 @@ TEST_F(HotcueControlTest, SavedLoopUseLoopInOutWhileActive) { EXPECT_DOUBLE_EQ(Cue::kNoPosition, m_pHotcue1EndPosition->get()); // Set a beatloop - m_pBeatloopActivate->slotSet(1); - m_pBeatloopActivate->slotSet(0); + m_pBeatloopActivate->set(1); + m_pBeatloopActivate->set(0); ProcessBuffer(); // Save currently active loop to hotcue slot 1 - m_pHotcue1SetLoop->slotSet(1); - m_pHotcue1SetLoop->slotSet(0); + m_pHotcue1SetLoop->set(1); + m_pHotcue1SetLoop->set(0); ProcessBuffer(); EXPECT_DOUBLE_EQ(static_cast(HotcueControl::Status::Active), m_pHotcue1Enabled->get()); EXPECT_NE(Cue::kNoPosition, m_pHotcue1Position->get()); @@ -1285,14 +1285,14 @@ TEST_F(HotcueControlTest, SavedLoopUseLoopInOutWhileActive) { setCurrentSamplePosition(0); - pLoopIn->slotSet(1); - pLoopIn->slotSet(0); + pLoopIn->set(1); + pLoopIn->set(0); ProcessBuffer(); setCurrentSamplePosition(1000); - pLoopOut->slotSet(1); - pLoopOut->slotSet(0); + pLoopOut->set(1); + pLoopOut->set(0); ProcessBuffer(); EXPECT_DOUBLE_EQ(static_cast(HotcueControl::Status::Active), m_pHotcue1Enabled->get()); diff --git a/src/test/looping_control_test.cpp b/src/test/looping_control_test.cpp index 57947e7209e..4380239c52f 100644 --- a/src/test/looping_control_test.cpp +++ b/src/test/looping_control_test.cpp @@ -113,8 +113,8 @@ class LoopingControlTest : public MockedEngineBackendTest { }; TEST_F(LoopingControlTest, LoopSet) { - m_pLoopStartPoint->slotSet(0); - m_pLoopEndPoint->slotSet(100); + m_pLoopStartPoint->set(0); + m_pLoopEndPoint->set(100); seekToSampleAndProcess(50); EXPECT_FALSE(isLoopEnabled()); EXPECT_EQ(0, m_pLoopStartPoint->get()); @@ -122,68 +122,68 @@ TEST_F(LoopingControlTest, LoopSet) { } TEST_F(LoopingControlTest, LoopSetOddSamples) { - m_pLoopStartPoint->slotSet(1); - m_pLoopEndPoint->slotSet(101.5); + m_pLoopStartPoint->set(1); + m_pLoopEndPoint->set(101.5); seekToSampleAndProcess(50); EXPECT_EQ(1, m_pLoopStartPoint->get()); EXPECT_EQ(101.5, m_pLoopEndPoint->get()); } TEST_F(LoopingControlTest, LoopInSetInsideLoopContinues) { - m_pLoopStartPoint->slotSet(0); - m_pLoopEndPoint->slotSet(100); - m_pButtonReloopToggle->slotSet(1); - m_pButtonReloopToggle->slotSet(0); + m_pLoopStartPoint->set(0); + m_pLoopEndPoint->set(100); + m_pButtonReloopToggle->set(1); + m_pButtonReloopToggle->set(0); seekToSampleAndProcess(50); EXPECT_TRUE(isLoopEnabled()); EXPECT_EQ(0, m_pLoopStartPoint->get()); EXPECT_EQ(100, m_pLoopEndPoint->get()); - m_pLoopStartPoint->slotSet(10); + m_pLoopStartPoint->set(10); EXPECT_TRUE(isLoopEnabled()); EXPECT_EQ(10, m_pLoopStartPoint->get()); EXPECT_EQ(100, m_pLoopEndPoint->get()); } TEST_F(LoopingControlTest, LoopInSetAfterLoopOutStops) { - m_pLoopStartPoint->slotSet(0); - m_pLoopEndPoint->slotSet(100); - m_pButtonReloopToggle->slotSet(1); - m_pButtonReloopToggle->slotSet(0); + m_pLoopStartPoint->set(0); + m_pLoopEndPoint->set(100); + m_pButtonReloopToggle->set(1); + m_pButtonReloopToggle->set(0); seekToSampleAndProcess(50); EXPECT_TRUE(isLoopEnabled()); EXPECT_EQ(0, m_pLoopStartPoint->get()); EXPECT_EQ(100, m_pLoopEndPoint->get()); - m_pLoopStartPoint->slotSet(110); + m_pLoopStartPoint->set(110); EXPECT_FALSE(isLoopEnabled()); EXPECT_EQ(110, m_pLoopStartPoint->get()); EXPECT_EQ(-1, m_pLoopEndPoint->get()); } TEST_F(LoopingControlTest, LoopOutSetInsideLoopContinues) { - m_pLoopStartPoint->slotSet(0); - m_pLoopEndPoint->slotSet(100); - m_pButtonReloopToggle->slotSet(1); - m_pButtonReloopToggle->slotSet(0); + m_pLoopStartPoint->set(0); + m_pLoopEndPoint->set(100); + m_pButtonReloopToggle->set(1); + m_pButtonReloopToggle->set(0); seekToSampleAndProcess(50); EXPECT_TRUE(isLoopEnabled()); EXPECT_EQ(0, m_pLoopStartPoint->get()); EXPECT_EQ(100, m_pLoopEndPoint->get()); - m_pLoopEndPoint->slotSet(80); + m_pLoopEndPoint->set(80); EXPECT_TRUE(isLoopEnabled()); EXPECT_EQ(0, m_pLoopStartPoint->get()); EXPECT_EQ(80, m_pLoopEndPoint->get()); } TEST_F(LoopingControlTest, LoopOutSetBeforeLoopInIgnored) { - m_pLoopStartPoint->slotSet(10); - m_pLoopEndPoint->slotSet(100); - m_pButtonReloopToggle->slotSet(1); - m_pButtonReloopToggle->slotSet(0); + m_pLoopStartPoint->set(10); + m_pLoopEndPoint->set(100); + m_pButtonReloopToggle->set(1); + m_pButtonReloopToggle->set(0); seekToSampleAndProcess(50); EXPECT_TRUE(isLoopEnabled()); EXPECT_EQ(10, m_pLoopStartPoint->get()); EXPECT_EQ(100, m_pLoopEndPoint->get()); - m_pLoopEndPoint->slotSet(0); + m_pLoopEndPoint->set(0); EXPECT_TRUE(isLoopEnabled()); EXPECT_EQ(10, m_pLoopStartPoint->get()); EXPECT_EQ(100, m_pLoopEndPoint->get()); @@ -194,8 +194,8 @@ TEST_F(LoopingControlTest, LoopInButton_QuantizeDisabled) { m_pClosestBeat->set(100); m_pNextBeat->set(100); seekToSampleAndProcess(50); - m_pButtonLoopIn->slotSet(1); - m_pButtonLoopIn->slotSet(0); + m_pButtonLoopIn->set(1); + m_pButtonLoopIn->set(0); ProcessBuffer(); EXPECT_EQ(50, m_pLoopStartPoint->get()); } @@ -205,30 +205,30 @@ TEST_F(LoopingControlTest, LoopInButton_QuantizeEnabledNoBeats) { m_pClosestBeat->set(-1); m_pNextBeat->set(-1); seekToSampleAndProcess(50); - m_pButtonLoopIn->slotSet(1); - m_pButtonLoopIn->slotSet(0); + m_pButtonLoopIn->set(1); + m_pButtonLoopIn->set(0); EXPECT_EQ(50, m_pLoopStartPoint->get()); } TEST_F(LoopingControlTest, LoopInButton_AdjustLoopInPointOutsideLoop) { - m_pLoopStartPoint->slotSet(1000); - m_pLoopEndPoint->slotSet(2000); - m_pButtonReloopToggle->slotSet(1); - m_pButtonReloopToggle->slotSet(0); - m_pButtonLoopIn->slotSet(1); + m_pLoopStartPoint->set(1000); + m_pLoopEndPoint->set(2000); + m_pButtonReloopToggle->set(1); + m_pButtonReloopToggle->set(0); + m_pButtonLoopIn->set(1); seekToSampleAndProcess(50); - m_pButtonLoopIn->slotSet(0); + m_pButtonLoopIn->set(0); EXPECT_EQ(50, m_pLoopStartPoint->get()); } TEST_F(LoopingControlTest, LoopInButton_AdjustLoopInPointInsideLoop) { - m_pLoopStartPoint->slotSet(1000); - m_pLoopEndPoint->slotSet(2000); - m_pButtonReloopToggle->slotSet(1); - m_pButtonReloopToggle->slotSet(0); - m_pButtonLoopIn->slotSet(1); + m_pLoopStartPoint->set(1000); + m_pLoopEndPoint->set(2000); + m_pButtonReloopToggle->set(1); + m_pButtonReloopToggle->set(0); + m_pButtonLoopIn->set(1); seekToSampleAndProcess(1500); - m_pButtonLoopIn->slotSet(0); + m_pButtonLoopIn->set(0); EXPECT_EQ(1500, m_pLoopStartPoint->get()); } @@ -237,9 +237,9 @@ TEST_F(LoopingControlTest, LoopOutButton_QuantizeDisabled) { m_pClosestBeat->set(1000); m_pNextBeat->set(1000); seekToSampleAndProcess(500); - m_pLoopStartPoint->slotSet(0); - m_pButtonLoopOut->slotSet(1); - m_pButtonLoopOut->slotSet(0); + m_pLoopStartPoint->set(0); + m_pButtonLoopOut->set(1); + m_pButtonLoopOut->set(0); EXPECT_EQ(500, m_pLoopEndPoint->get()); } @@ -248,31 +248,31 @@ TEST_F(LoopingControlTest, LoopOutButton_QuantizeEnabledNoBeats) { m_pClosestBeat->set(-1); m_pNextBeat->set(-1); seekToSampleAndProcess(500); - m_pLoopStartPoint->slotSet(0); - m_pButtonLoopOut->slotSet(1); - m_pButtonLoopOut->slotSet(0); + m_pLoopStartPoint->set(0); + m_pButtonLoopOut->set(1); + m_pButtonLoopOut->set(0); EXPECT_EQ(500, m_pLoopEndPoint->get()); } TEST_F(LoopingControlTest, LoopOutButton_AdjustLoopOutPointOutsideLoop) { - m_pLoopStartPoint->slotSet(1000); - m_pLoopEndPoint->slotSet(2000); - m_pButtonReloopToggle->slotSet(1); - m_pButtonReloopToggle->slotSet(0); - m_pButtonLoopOut->slotSet(1); + m_pLoopStartPoint->set(1000); + m_pLoopEndPoint->set(2000); + m_pButtonReloopToggle->set(1); + m_pButtonReloopToggle->set(0); + m_pButtonLoopOut->set(1); seekToSampleAndProcess(3000); - m_pButtonLoopOut->slotSet(0); + m_pButtonLoopOut->set(0); EXPECT_EQ(3000, m_pLoopEndPoint->get()); } TEST_F(LoopingControlTest, LoopOutButton_AdjustLoopOutPointInsideLoop) { - m_pLoopStartPoint->slotSet(100); - m_pLoopEndPoint->slotSet(2000); - m_pButtonReloopToggle->slotSet(1); - m_pButtonReloopToggle->slotSet(0); - m_pButtonLoopOut->slotSet(1); + m_pLoopStartPoint->set(100); + m_pLoopEndPoint->set(2000); + m_pButtonReloopToggle->set(1); + m_pButtonReloopToggle->set(0); + m_pButtonLoopOut->set(1); seekToSampleAndProcess(1500); - m_pButtonLoopOut->slotSet(0); + m_pButtonLoopOut->set(0); EXPECT_EQ(1500, m_pLoopEndPoint->get()); } @@ -314,51 +314,51 @@ TEST_F(LoopingControlTest, ReloopToggleButton_TogglesLoop) { m_pClosestBeat->set(-1); m_pNextBeat->set(-1); seekToSampleAndProcess(500); - m_pLoopStartPoint->slotSet(0); - m_pButtonLoopOut->slotSet(1); - m_pButtonLoopOut->slotSet(0); + m_pLoopStartPoint->set(0); + m_pButtonLoopOut->set(1); + m_pButtonLoopOut->set(0); EXPECT_TRUE(isLoopEnabled()); EXPECT_EQ(0, m_pLoopStartPoint->get()); EXPECT_EQ(500, m_pLoopEndPoint->get()); - m_pButtonReloopToggle->slotSet(1); - m_pButtonReloopToggle->slotSet(0); + m_pButtonReloopToggle->set(1); + m_pButtonReloopToggle->set(0); EXPECT_FALSE(isLoopEnabled()); EXPECT_EQ(0, m_pLoopStartPoint->get()); EXPECT_EQ(500, m_pLoopEndPoint->get()); - m_pButtonReloopToggle->slotSet(1); - m_pButtonReloopToggle->slotSet(0); + m_pButtonReloopToggle->set(1); + m_pButtonReloopToggle->set(0); EXPECT_TRUE(isLoopEnabled()); EXPECT_EQ(0, m_pLoopStartPoint->get()); EXPECT_EQ(500, m_pLoopEndPoint->get()); // Ensure that the Loop Exit button works, and that it doesn't act as a // toggle. - m_pButtonLoopExit->slotSet(1); - m_pButtonLoopExit->slotSet(0); + m_pButtonLoopExit->set(1); + m_pButtonLoopExit->set(0); EXPECT_FALSE(isLoopEnabled()); - m_pButtonLoopExit->slotSet(1); - m_pButtonLoopExit->slotSet(0); + m_pButtonLoopExit->set(1); + m_pButtonLoopExit->set(0); EXPECT_FALSE(isLoopEnabled()); } TEST_F(LoopingControlTest, ReloopToggleButton_DoesNotJumpAhead) { - m_pLoopStartPoint->slotSet(1000); - m_pLoopEndPoint->slotSet(2000); + m_pLoopStartPoint->set(1000); + m_pLoopEndPoint->set(2000); seekToSampleAndProcess(0); - m_pButtonReloopToggle->slotSet(1); - m_pButtonReloopToggle->slotSet(0); + m_pButtonReloopToggle->set(1); + m_pButtonReloopToggle->set(0); seekToSampleAndProcess(50); EXPECT_LE(m_pChannel1->getEngineBuffer()->m_pLoopingControl->getSampleOfTrack().current, m_pLoopStartPoint->get()); } TEST_F(LoopingControlTest, ReloopAndStopButton) { - m_pLoopStartPoint->slotSet(1000); - m_pLoopEndPoint->slotSet(2000); + m_pLoopStartPoint->set(1000); + m_pLoopEndPoint->set(2000); seekToSampleAndProcess(1500); - m_pButtonReloopToggle->slotSet(1); - m_pButtonReloopToggle->slotSet(0); - m_pButtonReloopAndStop->slotSet(1); - m_pButtonReloopAndStop->slotSet(0); + m_pButtonReloopToggle->set(1); + m_pButtonReloopToggle->set(0); + m_pButtonReloopAndStop->set(1); + m_pButtonReloopAndStop->set(0); ProcessBuffer(); EXPECT_EQ(m_pChannel1->getEngineBuffer()->m_pLoopingControl->getSampleOfTrack().current, m_pLoopStartPoint->get()); EXPECT_TRUE(m_pLoopEnabled->toBool()); @@ -382,8 +382,8 @@ TEST_F(LoopingControlTest, LoopScale_DoublesLoop) { } TEST_F(LoopingControlTest, LoopScale_HalvesLoop) { - m_pLoopStartPoint->slotSet(0); - m_pLoopEndPoint->slotSet(2000); + m_pLoopStartPoint->set(0); + m_pLoopEndPoint->set(2000); seekToSampleAndProcess(1800); EXPECT_EQ(0, m_pLoopStartPoint->get()); EXPECT_EQ(2000, m_pLoopEndPoint->get()); @@ -398,7 +398,7 @@ TEST_F(LoopingControlTest, LoopScale_HalvesLoop) { // even though it is outside the loop. EXPECT_EQ(1800, m_pChannel1->getEngineBuffer()->m_pLoopingControl->getSampleOfTrack().current); - m_pButtonReloopToggle->slotSet(1); + m_pButtonReloopToggle->set(1); EXPECT_TRUE(isLoopEnabled()); m_pLoopScale->set(0.5); ProcessBuffer(); @@ -415,12 +415,12 @@ TEST_F(LoopingControlTest, LoopScale_HalvesLoop) { TEST_F(LoopingControlTest, LoopDoubleButton_IgnoresPastTrackEnd) { seekToSampleAndProcess(50); - m_pLoopStartPoint->slotSet(kTrackLengthSamples / 2.0); - m_pLoopEndPoint->slotSet(kTrackLengthSamples); + m_pLoopStartPoint->set(kTrackLengthSamples / 2.0); + m_pLoopEndPoint->set(kTrackLengthSamples); EXPECT_EQ(kTrackLengthSamples / 2.0, m_pLoopStartPoint->get()); EXPECT_EQ(kTrackLengthSamples, m_pLoopEndPoint->get()); - m_pButtonLoopDouble->slotSet(1); - m_pButtonLoopDouble->slotSet(0); + m_pButtonLoopDouble->set(1); + m_pButtonLoopDouble->set(0); EXPECT_EQ(kTrackLengthSamples / 2.0, m_pLoopStartPoint->get()); EXPECT_EQ(kTrackLengthSamples, m_pLoopEndPoint->get()); } @@ -444,8 +444,8 @@ TEST_F(LoopingControlTest, LoopDoubleButton_DoesNotResizeManualLoop) { m_pButtonLoopOut->set(0.0); EXPECT_EQ(500, m_pLoopStartPoint->get()); EXPECT_EQ(1000, m_pLoopEndPoint->get()); - m_pButtonLoopDouble->slotSet(1); - m_pButtonLoopDouble->slotSet(0); + m_pButtonLoopDouble->set(1); + m_pButtonLoopDouble->set(0); EXPECT_EQ(500, m_pLoopStartPoint->get()); EXPECT_EQ(1000, m_pLoopEndPoint->get()); } @@ -466,12 +466,12 @@ TEST_F(LoopingControlTest, LoopDoubleButton_UpdatesNumberedBeatloopActivationCon TEST_F(LoopingControlTest, LoopHalveButton_IgnoresTooSmall) { ProcessBuffer(); - m_pLoopStartPoint->slotSet(0); - m_pLoopEndPoint->slotSet(40); + m_pLoopStartPoint->set(0); + m_pLoopEndPoint->set(40); EXPECT_EQ(0, m_pLoopStartPoint->get()); EXPECT_EQ(40, m_pLoopEndPoint->get()); - m_pButtonLoopHalve->slotSet(1); - m_pButtonLoopHalve->slotSet(0); + m_pButtonLoopHalve->set(1); + m_pButtonLoopHalve->set(0); EXPECT_EQ(0, m_pLoopStartPoint->get()); EXPECT_EQ(40, m_pLoopEndPoint->get()); } @@ -481,8 +481,8 @@ TEST_F(LoopingControlTest, LoopHalveButton_HalvesBeatloopSize) { m_pBeatLoopSize->set(64.0); m_pButtonBeatLoopActivate->set(1.0); m_pButtonBeatLoopActivate->set(0.0); - m_pButtonLoopHalve->slotSet(1); - m_pButtonLoopHalve->slotSet(0); + m_pButtonLoopHalve->set(1); + m_pButtonLoopHalve->set(0); EXPECT_EQ(32.0, m_pBeatLoopSize->get()); } @@ -495,8 +495,8 @@ TEST_F(LoopingControlTest, LoopHalveButton_DoesNotResizeManualLoop) { m_pButtonLoopOut->set(0.0); EXPECT_EQ(500, m_pLoopStartPoint->get()); EXPECT_EQ(1000, m_pLoopEndPoint->get()); - m_pButtonLoopHalve->slotSet(1); - m_pButtonLoopHalve->slotSet(0); + m_pButtonLoopHalve->set(1); + m_pButtonLoopHalve->set(0); EXPECT_EQ(500, m_pLoopStartPoint->get()); EXPECT_EQ(1000, m_pLoopEndPoint->get()); } @@ -517,10 +517,10 @@ TEST_F(LoopingControlTest, LoopHalveButton_UpdatesNumberedBeatloopActivationCont TEST_F(LoopingControlTest, LoopMoveTest) { m_pTrack1->trySetBpm(120); - m_pLoopStartPoint->slotSet(0); - m_pLoopEndPoint->slotSet(300); + m_pLoopStartPoint->set(0); + m_pLoopEndPoint->set(300); seekToSampleAndProcess(10); - m_pButtonReloopToggle->slotSet(1); + m_pButtonReloopToggle->set(1); EXPECT_TRUE(isLoopEnabled()); EXPECT_EQ(0, m_pLoopStartPoint->get()); EXPECT_EQ(300, m_pLoopEndPoint->get()); @@ -550,7 +550,7 @@ TEST_F(LoopingControlTest, LoopMoveTest) { // Now repeat the test with looping disabled (should not affect the // playhead). - m_pButtonReloopToggle->slotSet(1); + m_pButtonReloopToggle->set(1); EXPECT_FALSE(isLoopEnabled()); // Move the loop out from under the playposition. @@ -585,10 +585,10 @@ TEST_F(LoopingControlTest, LoopResizeSeek) { m_pQuantizeEnabled->set(0.0); m_pTrack1->trySetBpm(23520); - m_pLoopStartPoint->slotSet(0); - m_pLoopEndPoint->slotSet(600); + m_pLoopStartPoint->set(0); + m_pLoopEndPoint->set(600); seekToSampleAndProcess(500); - m_pButtonReloopToggle->slotSet(1); + m_pButtonReloopToggle->set(1); EXPECT_TRUE(isLoopEnabled()); EXPECT_EQ(0, m_pLoopStartPoint->get()); EXPECT_EQ(600, m_pLoopEndPoint->get()); @@ -607,10 +607,10 @@ TEST_F(LoopingControlTest, LoopResizeSeek) { EXPECT_EQ(50, m_pChannel1->getEngineBuffer()->m_pLoopingControl->getSampleOfTrack().current); // But if looping is not enabled, no warping occurs. - m_pLoopStartPoint->slotSet(0); - m_pLoopEndPoint->slotSet(600); + m_pLoopStartPoint->set(0); + m_pLoopEndPoint->set(600); seekToSampleAndProcess(500); - m_pButtonReloopToggle->slotSet(1); + m_pButtonReloopToggle->set(1); EXPECT_FALSE(isLoopEnabled()); EXPECT_EQ(0, m_pLoopStartPoint->get()); EXPECT_EQ(600, m_pLoopEndPoint->get()); @@ -755,11 +755,11 @@ TEST_F(LoopingControlTest, BeatLoopSize_ValueChangeDoesNotResizeManualLoop) { m_pTrack1->trySetBpm(160.0); m_pQuantizeEnabled->set(0); m_pBeatLoopSize->set(4.0); - m_pButtonLoopIn->slotSet(1); - m_pButtonLoopIn->slotSet(0); + m_pButtonLoopIn->set(1); + m_pButtonLoopIn->set(0); seekToSampleAndProcess(500); - m_pButtonLoopOut->slotSet(1); - m_pButtonLoopOut->slotSet(0); + m_pButtonLoopOut->set(1); + m_pButtonLoopOut->set(0); double oldLoopStart = m_pLoopStartPoint->get(); double oldLoopEnd = m_pLoopEndPoint->get(); @@ -872,8 +872,8 @@ TEST_F(LoopingControlTest, Beatjump_MovesLoopBoundaries) { } TEST_F(LoopingControlTest, LoopEscape) { - m_pLoopStartPoint->slotSet(100); - m_pLoopEndPoint->slotSet(200); + m_pLoopStartPoint->set(100); + m_pLoopEndPoint->set(200); m_pButtonReloopToggle->set(1.0); m_pButtonReloopToggle->set(0.0); ProcessBuffer(); @@ -966,14 +966,14 @@ TEST_F(LoopingControlTest, BeatLoopRoll_StartPoint) { m_pTrack1->trySetBpm(120.0); // start a 4 beat loop roll, start point should be overridden to play position - m_pLoopStartPoint->slotSet(8); + m_pLoopStartPoint->set(8); m_pButtonBeatLoopRoll4Activate->set(1.0); EXPECT_TRUE(m_pLoopEnabled->toBool()); EXPECT_TRUE(m_pBeatLoop4Enabled->toBool()); EXPECT_EQ(0, m_pLoopStartPoint->get()); // move the start point, activate a 1 beat loop roll, new start point be preserved - m_pLoopStartPoint->slotSet(8); + m_pLoopStartPoint->set(8); m_pButtonBeatLoopRoll1Activate->set(1.0); EXPECT_TRUE(m_pLoopEnabled->toBool()); EXPECT_TRUE(m_pBeatLoop1Enabled->toBool()); diff --git a/src/vinylcontrol/vinylcontrol.cpp b/src/vinylcontrol/vinylcontrol.cpp index 9f89c12281c..4d24a9b5059 100644 --- a/src/vinylcontrol/vinylcontrol.cpp +++ b/src/vinylcontrol/vinylcontrol.cpp @@ -52,21 +52,21 @@ void VinylControl::toggleVinylControl(bool enable) { m_pConfig->set(ConfigKey(m_group,"vinylcontrol_enabled"), ConfigValue((int)enable)); } - enabled->slotSet(enable); + enabled->set(enable); // Reset the scratch control to make sure we don't get stuck moving forwards or backwards. // actually that might be a good thing //if (!enable) - // controlScratch->slotSet(0.0); + // controlScratch->set(0.0); } VinylControl::~VinylControl() { bool wasEnabled = m_bIsEnabled; - enabled->slotSet(false); - vinylStatus->slotSet(VINYL_STATUS_DISABLED); + enabled->set(false); + vinylStatus->set(VINYL_STATUS_DISABLED); if (wasEnabled) { // if vinyl control is just restarting, indicate that it should // be enabled - wantenabled->slotSet(true); + wantenabled->set(true); } } diff --git a/src/vinylcontrol/vinylcontrolxwax.cpp b/src/vinylcontrol/vinylcontrolxwax.cpp index 70b61ee03de..eff084556ca 100644 --- a/src/vinylcontrol/vinylcontrolxwax.cpp +++ b/src/vinylcontrol/vinylcontrolxwax.cpp @@ -59,8 +59,9 @@ VinylControlXwax::VinylControlXwax(UserSettingsPointer pConfig, const QString& g m_dUiUpdateTime(-1.0) { // TODO(rryan): Should probably live in VinylControlManager since it's not // specific to a VC deck. - signalenabled->slotSet(m_pConfig->getValueString( - ConfigKey(VINYL_PREF_KEY, "show_signal_quality")).toInt()); + signalenabled->set(m_pConfig->getValueString( + ConfigKey(VINYL_PREF_KEY, "show_signal_quality")) + .toInt()); // Get the vinyl type and speed. QString strVinylType = m_pConfig->getValueString( @@ -293,7 +294,7 @@ void VinylControlXwax::analyzeSamples(CSAMPLE* pSamples, size_t nFrames) { //to absolute mode (would cause sudden track skip) if (reportedPlayButton && reportedMode == MIXXX_VCMODE_ABSOLUTE) { m_iVCMode = MIXXX_VCMODE_RELATIVE; - mode->slotSet((double)m_iVCMode); + mode->set((double)m_iVCMode); } else { // go ahead and switch m_iVCMode = reportedMode; @@ -305,14 +306,14 @@ void VinylControlXwax::analyzeSamples(CSAMPLE* pSamples, size_t nFrames) { //if we are out of error mode... if (vinylStatus->get() == VINYL_STATUS_ERROR && m_iVCMode == MIXXX_VCMODE_RELATIVE) { - vinylStatus->slotSet(VINYL_STATUS_OK); + vinylStatus->set(VINYL_STATUS_OK); } } //if looping has been enabled, don't allow absolute mode if (loopEnabled->toBool() && m_iVCMode == MIXXX_VCMODE_ABSOLUTE) { m_iVCMode = MIXXX_VCMODE_RELATIVE; - mode->slotSet((double)m_iVCMode); + mode->set((double)m_iVCMode); } // Don't allow cueing mode to be enabled in absolute mode. @@ -358,9 +359,9 @@ void VinylControlXwax::analyzeSamples(CSAMPLE* pSamples, size_t nFrames) { //ok, it's still valid, blink if ((reportedPlayButton && (int)(filePosition * 2.0) % 2) || (!reportedPlayButton && (int)(m_iPosition / 500.0) % 2)) { - vinylStatus->slotSet(VINYL_STATUS_WARNING); + vinylStatus->set(VINYL_STATUS_WARNING); } else { - vinylStatus->slotSet(VINYL_STATUS_DISABLED); + vinylStatus->set(VINYL_STATUS_DISABLED); } } } @@ -411,8 +412,8 @@ void VinylControlXwax::analyzeSamples(CSAMPLE* pSamples, size_t nFrames) { m_group, "LoadSelectedTrack", this); } - m_pControlTrackLoader->slotSet(1.0); - m_pControlTrackLoader->slotSet(0.0); // I think I have to do this... + m_pControlTrackLoader->set(1.0); + m_pControlTrackLoader->set(0.0); // I think I have to do this... // if position is known and safe then no track select mode m_bTrackSelectMode = false; @@ -635,14 +636,14 @@ void VinylControlXwax::analyzeSamples(CSAMPLE* pSamples, size_t nFrames) { m_iQualPos = 0; m_iQualFilled = 0; m_bForceResync = true; - vinylStatus->slotSet(VINYL_STATUS_OK); + vinylStatus->set(VINYL_STATUS_OK); } } } void VinylControlXwax::enableRecordEndMode() { qDebug() << "record end, setting constant mode"; - vinylStatus->slotSet(VINYL_STATUS_WARNING); + vinylStatus->set(VINYL_STATUS_WARNING); enableConstantMode(); m_bAtRecordEnd = true; } @@ -650,7 +651,7 @@ void VinylControlXwax::enableRecordEndMode() { void VinylControlXwax::enableConstantMode() { m_iOldVCMode = m_iVCMode; m_iVCMode = MIXXX_VCMODE_CONSTANT; - mode->slotSet((double)m_iVCMode); + mode->set((double)m_iVCMode); togglePlayButton(true); double rate = m_pVCRate->get(); m_pRateRatio->set(fabs(rate)); @@ -660,22 +661,22 @@ void VinylControlXwax::enableConstantMode() { void VinylControlXwax::enableConstantMode(double rate) { m_iOldVCMode = m_iVCMode; m_iVCMode = MIXXX_VCMODE_CONSTANT; - mode->slotSet((double)m_iVCMode); + mode->set((double)m_iVCMode); togglePlayButton(true); m_pRateRatio->set(fabs(rate)); m_pVCRate->set(rate); } void VinylControlXwax::disableRecordEndMode() { - vinylStatus->slotSet(VINYL_STATUS_OK); + vinylStatus->set(VINYL_STATUS_OK); m_bAtRecordEnd = false; m_iVCMode = MIXXX_VCMODE_RELATIVE; - mode->slotSet((double)m_iVCMode); + mode->set((double)m_iVCMode); } void VinylControlXwax::togglePlayButton(bool on) { if (m_bIsEnabled && (playButton->get() > 0) != on) { - playButton->slotSet((float)on); //and we all float on all right + playButton->set((float)on); //and we all float on all right } } @@ -736,9 +737,9 @@ double VinylControlXwax::checkSteadyPitch(double pitch, double time) { return 0; } if (m_pSteadyGross->check(pitch, time) < 0.5) { - scratching->slotSet(1.0); + scratching->set(1.0); } else { - scratching->slotSet(0.0); + scratching->set(0.0); } return m_pSteadySubtle->check(pitch, time); } @@ -747,15 +748,15 @@ double VinylControlXwax::checkSteadyPitch(double pitch, double time) { void VinylControlXwax::syncPosition() { //qDebug() << "sync position" << m_dVinylPosition / m_dOldDuration; // VinylPos in seconds / total length of song. - vinylSeek->slotSet(m_dVinylPosition / m_dOldDuration); + vinylSeek->set(m_dVinylPosition / m_dOldDuration); } bool VinylControlXwax::checkEnabled(bool was, bool is) { // if we're not enabled, but the last object was, try turning ourselves on // XXX: is this just a race that's working right now? if (!is && wantenabled->get() > 0) { - enabled->slotSet(true); - wantenabled->slotSet(false); //don't try to do this over and over + enabled->set(true); + wantenabled->set(false); //don't try to do this over and over return true; //optimism! } @@ -777,9 +778,9 @@ bool VinylControlXwax::checkEnabled(bool was, bool is) { } if (is && !was) { - vinylStatus->slotSet(VINYL_STATUS_OK); + vinylStatus->set(VINYL_STATUS_OK); } else if (!is) { - vinylStatus->slotSet(VINYL_STATUS_DISABLED); + vinylStatus->set(VINYL_STATUS_DISABLED); } return is; diff --git a/src/widget/wwaveformviewer.cpp b/src/widget/wwaveformviewer.cpp index 04184dfa497..54f8f631b32 100644 --- a/src/widget/wwaveformviewer.cpp +++ b/src/widget/wwaveformviewer.cpp @@ -82,7 +82,7 @@ void WWaveformViewer::mousePressEvent(QMouseEvent* event) { double audioSamplePerPixel = m_waveformWidget->getAudioSamplePerPixel(); double targetPosition = -1.0 * eventPosValue * audioSamplePerPixel * 2; m_pScratchPosition->set(targetPosition); - m_pScratchPositionEnable->slotSet(1.0); + m_pScratchPositionEnable->set(1.0); } else if (event->button() == Qt::RightButton) { const auto currentTrack = m_waveformWidget->getTrackInfo(); if (!isPlaying() && m_pHoveredMark) { @@ -95,7 +95,7 @@ void WWaveformViewer::mousePressEvent(QMouseEvent* event) { // If we are scratching then disable and reset because the two shouldn't // be used at once. if (m_bScratching) { - m_pScratchPositionEnable->slotSet(0.0); + m_pScratchPositionEnable->set(0.0); m_bScratching = false; } m_pWheel->setParameter(0.5); From 156eb902d78677448656a2c84190f9c3fa7b0749 Mon Sep 17 00:00:00 2001 From: Uwe Klotz Date: Thu, 15 Jul 2021 16:36:36 +0200 Subject: [PATCH 03/25] AutoDJCratesDAO: Fix crash after loading/unloading tracks --- src/library/dao/autodjcratesdao.cpp | 25 ++++++++++++++----------- src/library/dao/autodjcratesdao.h | 4 ++-- 2 files changed, 16 insertions(+), 13 deletions(-) diff --git a/src/library/dao/autodjcratesdao.cpp b/src/library/dao/autodjcratesdao.cpp index 7bb25346215..c4070b3d6ac 100644 --- a/src/library/dao/autodjcratesdao.cpp +++ b/src/library/dao/autodjcratesdao.cpp @@ -1072,24 +1072,25 @@ void AutoDJCratesDAO::slotPlaylistTrackRemoved(int playlistId, void AutoDJCratesDAO::slotPlayerInfoTrackChanged( const QString& group, TrackPointer pNewTrack, TrackPointer pOldTrack) { - playerInfoTrackUnloaded(group, pOldTrack); - playerInfoTrackLoaded(group, pNewTrack); + if (pOldTrack) { + playerInfoTrackUnloaded(group, pOldTrack->getId()); + } + if (pNewTrack) { + playerInfoTrackLoaded(group, pNewTrack->getId()); + } } // Signaled by the PlayerInfo singleton when a track is loaded to a deck. -void AutoDJCratesDAO::playerInfoTrackLoaded(const QString& a_strGroup, - TrackPointer a_pTrack) { - // This gets called with a null track during an unload. Filter that out. - if (a_pTrack == nullptr) { +void AutoDJCratesDAO::playerInfoTrackLoaded(const QString& group, + TrackId trackId) { + VERIFY_OR_DEBUG_ASSERT(trackId.isValid()) { return; } - // This counts as an auto-DJ reference. The idea is to prevent tracks that // are loaded into a deck from being randomly chosen. - TrackId trackId(a_pTrack->getId()); unsigned int numDecks = PlayerManager::numDecks(); for (unsigned int i = 0; i < numDecks; ++i) { - if (a_strGroup == PlayerManager::groupForDeck(i)) { + if (group == PlayerManager::groupForDeck(i)) { // Update the number of auto-DJ-playlist references to this track. QSqlQuery oQuery(m_database); // UPDATE temp_autodj_crates SET autodjrefs = autodjrefs + 1 @@ -1109,10 +1110,12 @@ void AutoDJCratesDAO::playerInfoTrackLoaded(const QString& a_strGroup, // Signaled by the PlayerInfo singleton when a track is unloaded from a deck. void AutoDJCratesDAO::playerInfoTrackUnloaded(const QString& group, - TrackPointer pTrack) { + TrackId trackId) { + VERIFY_OR_DEBUG_ASSERT(trackId.isValid()) { + return; + } // This counts as an auto-DJ reference. The idea is to prevent tracks that // are loaded into a deck from being randomly chosen. - TrackId trackId(pTrack->getId()); unsigned int numDecks = PlayerManager::numDecks(); for (unsigned int i = 0; i < numDecks; ++i) { if (group == PlayerManager::groupForDeck(i)) { diff --git a/src/library/dao/autodjcratesdao.h b/src/library/dao/autodjcratesdao.h index 6e1be97411f..e82514340bd 100644 --- a/src/library/dao/autodjcratesdao.h +++ b/src/library/dao/autodjcratesdao.h @@ -97,8 +97,8 @@ class AutoDJCratesDAO : public QObject { TrackPointer pOldTrack); private: - void playerInfoTrackLoaded(const QString& group, TrackPointer pTrack); - void playerInfoTrackUnloaded(const QString& group, TrackPointer pTrack); + void playerInfoTrackLoaded(const QString& group, TrackId trackId); + void playerInfoTrackUnloaded(const QString& group, TrackId trackId); void updateAutoDjCrate(CrateId crateId); void deleteAutoDjCrate(CrateId crateId); From 6cf01185aaa77a52f19ad1bc299bfd6824e640bd Mon Sep 17 00:00:00 2001 From: Jan Holthuis Date: Fri, 16 Jul 2021 10:48:19 +0200 Subject: [PATCH 04/25] MixxxMainWindow: Move screensaver inhibitor code into CoreServices --- CMakeLists.txt | 1 + src/coreservices.cpp | 8 +++ src/coreservices.h | 8 +++ src/mixxxmainwindow.cpp | 62 +-------------------- src/mixxxmainwindow.h | 1 - src/preferences/dialog/dlgpreferences.cpp | 11 +++- src/preferences/dialog/dlgpreferences.h | 2 + src/preferences/dialog/dlgprefinterface.cpp | 11 ++-- src/preferences/dialog/dlgprefinterface.h | 3 + src/util/screensavermanager.cpp | 55 ++++++++++++++++++ src/util/screensavermanager.h | 29 ++++++++++ 11 files changed, 124 insertions(+), 67 deletions(-) create mode 100644 src/util/screensavermanager.cpp create mode 100644 src/util/screensavermanager.h diff --git a/CMakeLists.txt b/CMakeLists.txt index 20e471bd481..710c2613fb3 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -888,6 +888,7 @@ add_library(mixxx-lib STATIC EXCLUDE_FROM_ALL src/util/sandbox.cpp src/util/semanticversion.cpp src/util/screensaver.cpp + src/util/screensavermanager.cpp src/util/sleepableqthread.cpp src/util/stat.cpp src/util/statmodel.cpp diff --git a/src/coreservices.cpp b/src/coreservices.cpp index 0b8b43c595f..531e9fda77c 100644 --- a/src/coreservices.cpp +++ b/src/coreservices.cpp @@ -30,6 +30,7 @@ #include "util/font.h" #include "util/logger.h" #include "util/screensaver.h" +#include "util/screensavermanager.h" #include "util/statsmanager.h" #include "util/time.h" #include "util/translations.h" @@ -261,6 +262,13 @@ void CoreServices::initialize(QApplication* pApp) { m_pVCManager->init(); #endif + // Inhibit Screensaver + m_pScreensaverManager = std::make_shared(pConfig); + connect(&PlayerInfo::instance(), + &PlayerInfo::currentPlayingDeckChanged, + m_pScreensaverManager.get(), + &ScreensaverManager::slotCurrentPlayingDeckChanged); + emit initializationProgressUpdate(50, tr("library")); CoverArtCache::createInstance(); diff --git a/src/coreservices.h b/src/coreservices.h index d9f94288123..40d55df74e2 100644 --- a/src/coreservices.h +++ b/src/coreservices.h @@ -28,6 +28,7 @@ class LV2Backend; namespace mixxx { class DbConnectionPool; +class ScreensaverManager; class CoreServices : public QObject { Q_OBJECT @@ -39,6 +40,7 @@ class CoreServices : public QObject { void initializeSettings(); // FIXME: should be private, but WMainMenuBar needs it initialized early void initializeKeyboard(); + void initializeScreensaverManager(); void initialize(QApplication* pApp); void shutdown(); @@ -100,6 +102,10 @@ class CoreServices : public QObject { return m_pSettingsManager->settings(); } + std::shared_ptr getScreensaverManager() const { + return m_pScreensaverManager; + } + signals: void initializationProgressUpdate(int progress, const QString& serviceName); @@ -132,6 +138,8 @@ class CoreServices : public QObject { std::shared_ptr> m_pKbdConfig; std::shared_ptr> m_pKbdConfigEmpty; + std::shared_ptr m_pScreensaverManager; + std::unique_ptr m_pTouchShift; Timer m_runtime_timer; diff --git a/src/mixxxmainwindow.cpp b/src/mixxxmainwindow.cpp index dd9647ecf1b..fe8baecceee 100644 --- a/src/mixxxmainwindow.cpp +++ b/src/mixxxmainwindow.cpp @@ -130,20 +130,10 @@ MixxxMainWindow::MixxxMainWindow( this, &MixxxMainWindow::initializationProgressUpdate); - // Inhibit the screensaver if the option is set. (Do it before creating the preferences dialog) - UserSettingsPointer pConfig = m_pCoreServices->getSettings(); - int inhibit = pConfig->getValue(ConfigKey("[Config]", "InhibitScreensaver"), -1); - if (inhibit == -1) { - inhibit = static_cast(mixxx::ScreenSaverPreference::PREVENT_ON); - pConfig->setValue(ConfigKey("[Config]", "InhibitScreensaver"), inhibit); - } - m_inhibitScreensaver = static_cast(inhibit); - if (m_inhibitScreensaver == mixxx::ScreenSaverPreference::PREVENT_ON) { - mixxx::ScreenSaverHelper::inhibit(); - } - m_pCoreServices->initialize(pApp); + UserSettingsPointer pConfig = m_pCoreServices->getSettings(); + // Set the visibility of tooltips, default "1" = ON m_toolTipsCfg = static_cast( pConfig->getValue(ConfigKey("[Controls]", "Tooltips"), @@ -230,6 +220,7 @@ MixxxMainWindow::MixxxMainWindow( // Initialize preference dialog m_pPrefDlg = new DlgPreferences( this, + m_pCoreServices->getScreensaverManager(), m_pSkinLoader, m_pCoreServices->getSoundManager(), m_pCoreServices->getPlayerManager(), @@ -346,20 +337,12 @@ MixxxMainWindow::MixxxMainWindow( &PlayerInfo::currentPlayingTrackChanged, this, &MixxxMainWindow::slotUpdateWindowTitle); - connect(&PlayerInfo::instance(), - &PlayerInfo::currentPlayingDeckChanged, - this, - &MixxxMainWindow::slotChangedPlayingDeck); } MixxxMainWindow::~MixxxMainWindow() { Timer t("~MixxxMainWindow"); t.start(); - if (m_inhibitScreensaver != mixxx::ScreenSaverPreference::PREVENT_OFF) { - mixxx::ScreenSaverHelper::uninhibit(); - } - // Save the current window state (position, maximized, etc) // Note(ronso0): Unfortunately saveGeometry() also stores the fullscreen state. // On next start restoreGeometry would enable fullscreen mode even though that @@ -440,10 +423,6 @@ MixxxMainWindow::~MixxxMainWindow() { delete m_pGuiTick; delete m_pVisualsManager; - if (m_inhibitScreensaver != mixxx::ScreenSaverPreference::PREVENT_OFF) { - mixxx::ScreenSaverHelper::uninhibit(); - } - m_pCoreServices->shutdown(); } @@ -985,17 +964,6 @@ void MixxxMainWindow::slotNoAuxiliaryInputConfigured() { } } -void MixxxMainWindow::slotChangedPlayingDeck(int deck) { - if (m_inhibitScreensaver == mixxx::ScreenSaverPreference::PREVENT_ON_PLAY) { - if (deck==-1) { - // If no deck is playing, allow the screensaver to run. - mixxx::ScreenSaverHelper::uninhibit(); - } else { - mixxx::ScreenSaverHelper::inhibit(); - } - } -} - void MixxxMainWindow::slotHelpAbout() { DlgAbout* about = new DlgAbout(this); about->show(); @@ -1219,30 +1187,6 @@ bool MixxxMainWindow::confirmExit() { return true; } -void MixxxMainWindow::setInhibitScreensaver(mixxx::ScreenSaverPreference newInhibit) -{ - UserSettingsPointer pConfig = m_pCoreServices->getSettings(); - - if (m_inhibitScreensaver != mixxx::ScreenSaverPreference::PREVENT_OFF) { - mixxx::ScreenSaverHelper::uninhibit(); - } - - if (newInhibit == mixxx::ScreenSaverPreference::PREVENT_ON) { - mixxx::ScreenSaverHelper::inhibit(); - } else if (newInhibit == mixxx::ScreenSaverPreference::PREVENT_ON_PLAY - && PlayerInfo::instance().getCurrentPlayingDeck()!=-1) { - mixxx::ScreenSaverHelper::inhibit(); - } - int inhibit_int = static_cast(newInhibit); - pConfig->setValue(ConfigKey("[Config]","InhibitScreensaver"), inhibit_int); - m_inhibitScreensaver = newInhibit; -} - -mixxx::ScreenSaverPreference MixxxMainWindow::getInhibitScreensaver() -{ - return m_inhibitScreensaver; -} - void MixxxMainWindow::initializationProgressUpdate(int progress, const QString& serviceName) { if (m_pLaunchImage) { m_pLaunchImage->progress(progress, serviceName); diff --git a/src/mixxxmainwindow.h b/src/mixxxmainwindow.h index a593abb5abe..38419bad9e6 100644 --- a/src/mixxxmainwindow.h +++ b/src/mixxxmainwindow.h @@ -78,7 +78,6 @@ class MixxxMainWindow : public QMainWindow { void slotDeveloperToolsClosed(); void slotUpdateWindowTitle(TrackPointer pTrack); - void slotChangedPlayingDeck(int deck); /// warn the user when inputs are not configured. void slotNoMicrophoneInputConfigured(); diff --git a/src/preferences/dialog/dlgpreferences.cpp b/src/preferences/dialog/dlgpreferences.cpp index 24e80274340..61947724bf4 100644 --- a/src/preferences/dialog/dlgpreferences.cpp +++ b/src/preferences/dialog/dlgpreferences.cpp @@ -53,6 +53,7 @@ DlgPreferences::DlgPreferences( MixxxMainWindow* mixxx, + std::shared_ptr pScreensaverManager, std::shared_ptr pSkinLoader, std::shared_ptr pSoundManager, std::shared_ptr pPlayerManager, @@ -133,9 +134,13 @@ DlgPreferences::DlgPreferences( "ic_preferences_vinyl.svg"); #endif // __VINYLCONTROL__ - addPageWidget(PreferencesPage( - new DlgPrefInterface(this, mixxx, pSkinLoader, m_pConfig), - new QTreeWidgetItem(contentsTreeWidget, QTreeWidgetItem::Type)), + addPageWidget(PreferencesPage(new DlgPrefInterface(this, + mixxx, + pScreensaverManager, + pSkinLoader, + m_pConfig), + new QTreeWidgetItem( + contentsTreeWidget, QTreeWidgetItem::Type)), tr("Interface"), "ic_preferences_interface.svg"); diff --git a/src/preferences/dialog/dlgpreferences.h b/src/preferences/dialog/dlgpreferences.h index e48a28b3853..e44646f48a2 100644 --- a/src/preferences/dialog/dlgpreferences.h +++ b/src/preferences/dialog/dlgpreferences.h @@ -51,6 +51,7 @@ class DlgPrefModplug; #endif // __MODPLUG__ namespace mixxx { +class ScreensaverManager; namespace skin { class SkinLoader; } @@ -71,6 +72,7 @@ class DlgPreferences : public QDialog, public Ui::DlgPreferencesDlg { }; DlgPreferences(MixxxMainWindow* mixxx, + std::shared_ptr pScreensaverManager, std::shared_ptr pSkinLoader, std::shared_ptr pSoundManager, std::shared_ptr pPlayerManager, diff --git a/src/preferences/dialog/dlgprefinterface.cpp b/src/preferences/dialog/dlgprefinterface.cpp index a7bf2e21375..3a1d62dc5c3 100644 --- a/src/preferences/dialog/dlgprefinterface.cpp +++ b/src/preferences/dialog/dlgprefinterface.cpp @@ -18,6 +18,7 @@ #include "skin/skin.h" #include "skin/skinloader.h" #include "util/screensaver.h" +#include "util/screensavermanager.h" #include "util/widgethelper.h" using mixxx::skin::SkinManifest; @@ -26,11 +27,13 @@ using mixxx::skin::SkinPointer; DlgPrefInterface::DlgPrefInterface( QWidget* parent, MixxxMainWindow* mixxx, + std::shared_ptr pScreensaverManager, std::shared_ptr pSkinLoader, UserSettingsPointer pConfig) : DlgPreferencePage(parent), m_pConfig(pConfig), m_mixxx(mixxx), + m_pScreensaverManager(pScreensaverManager), m_pSkinLoader(pSkinLoader), m_pSkin(pSkinLoader->getConfiguredSkin()), m_dScaleFactorAuto(1.0), @@ -165,7 +168,7 @@ DlgPrefInterface::DlgPrefInterface( comboBoxScreensaver->addItem(tr("Prevent screensaver while playing"), static_cast(mixxx::ScreenSaverPreference::PREVENT_ON_PLAY)); - int inhibitsettings = static_cast(mixxx->getInhibitScreensaver()); + int inhibitsettings = static_cast(m_pScreensaverManager->status()); comboBoxScreensaver->setCurrentIndex(comboBoxScreensaver->findData(inhibitsettings)); // Tooltip configuration @@ -261,7 +264,7 @@ void DlgPrefInterface::slotUpdate() { loadTooltipPreferenceFromConfig(); - int inhibitsettings = static_cast(m_mixxx->getInhibitScreensaver()); + int inhibitsettings = static_cast(m_pScreensaverManager->status()); comboBoxScreensaver->setCurrentIndex(comboBoxScreensaver->findData(inhibitsettings)); } @@ -413,9 +416,9 @@ void DlgPrefInterface::slotApply() { // screensaver mode update int screensaverComboBoxState = comboBoxScreensaver->itemData( comboBoxScreensaver->currentIndex()).toInt(); - int screensaverConfiguredState = static_cast(m_mixxx->getInhibitScreensaver()); + int screensaverConfiguredState = static_cast(m_pScreensaverManager->status()); if (screensaverComboBoxState != screensaverConfiguredState) { - m_mixxx->setInhibitScreensaver( + m_pScreensaverManager->setStatus( static_cast(screensaverComboBoxState)); } diff --git a/src/preferences/dialog/dlgprefinterface.h b/src/preferences/dialog/dlgprefinterface.h index 6dbfd64d384..4b54e2d951d 100644 --- a/src/preferences/dialog/dlgprefinterface.h +++ b/src/preferences/dialog/dlgprefinterface.h @@ -18,6 +18,7 @@ class MixxxMainWindow; class ControlObject; namespace mixxx { +class ScreensaverManager; namespace skin { class SkinLoader; } @@ -29,6 +30,7 @@ class DlgPrefInterface : public DlgPreferencePage, public Ui::DlgPrefControlsDlg DlgPrefInterface( QWidget* parent, MixxxMainWindow* mixxx, + std::shared_ptr pScreensaverManager, std::shared_ptr pSkinLoader, UserSettingsPointer pConfig); ~DlgPrefInterface() override = default; @@ -62,6 +64,7 @@ class DlgPrefInterface : public DlgPreferencePage, public Ui::DlgPrefControlsDlg UserSettingsPointer m_pConfig; ControlObject* m_pControlTrackTimeDisplay; MixxxMainWindow *m_mixxx; + std::shared_ptr m_pScreensaverManager; std::shared_ptr m_pSkinLoader; QMap m_skins; diff --git a/src/util/screensavermanager.cpp b/src/util/screensavermanager.cpp new file mode 100644 index 00000000000..baf544e3cc1 --- /dev/null +++ b/src/util/screensavermanager.cpp @@ -0,0 +1,55 @@ +#include "util/screensavermanager.h" + +#include "mixer/playerinfo.h" + +namespace mixxx { + +ScreensaverManager::ScreensaverManager(UserSettingsPointer pConfig, QObject* pParent) + : QObject(pParent), m_pConfig(pConfig) { + int inhibit = pConfig->getValue(ConfigKey("[Config]", "InhibitScreensaver"), -1); + if (inhibit == -1) { + inhibit = static_cast(mixxx::ScreenSaverPreference::PREVENT_ON); + pConfig->setValue(ConfigKey("[Config]", "InhibitScreensaver"), inhibit); + } + m_inhibitScreensaver = static_cast(inhibit); + if (m_inhibitScreensaver == mixxx::ScreenSaverPreference::PREVENT_ON) { + mixxx::ScreenSaverHelper::inhibit(); + } +} + +ScreensaverManager::~ScreensaverManager() { + if (m_inhibitScreensaver != mixxx::ScreenSaverPreference::PREVENT_OFF) { + mixxx::ScreenSaverHelper::uninhibit(); + } +} + +void ScreensaverManager::setStatus(mixxx::ScreenSaverPreference newInhibit) { + if (m_inhibitScreensaver != mixxx::ScreenSaverPreference::PREVENT_OFF) { + mixxx::ScreenSaverHelper::uninhibit(); + } + + if (newInhibit == mixxx::ScreenSaverPreference::PREVENT_ON) { + mixxx::ScreenSaverHelper::inhibit(); + } else if (newInhibit == + mixxx::ScreenSaverPreference::PREVENT_ON_PLAY && + PlayerInfo::instance().getCurrentPlayingDeck() != -1) { + mixxx::ScreenSaverHelper::inhibit(); + } + int inhibit_int = static_cast(newInhibit); + m_pConfig->setValue(ConfigKey("[Config]", "InhibitScreensaver"), inhibit_int); + m_inhibitScreensaver = newInhibit; +} + +void ScreensaverManager::slotCurrentPlayingDeckChanged(int deck) { + if (m_inhibitScreensaver != mixxx::ScreenSaverPreference::PREVENT_ON_PLAY) { + return; + } + if (deck == -1) { + // If no deck is playing, allow the screensaver to run. + mixxx::ScreenSaverHelper::uninhibit(); + } else { + mixxx::ScreenSaverHelper::inhibit(); + } +} + +} // namespace mixxx diff --git a/src/util/screensavermanager.h b/src/util/screensavermanager.h new file mode 100644 index 00000000000..5af9223a006 --- /dev/null +++ b/src/util/screensavermanager.h @@ -0,0 +1,29 @@ +#pragma once +#include + +#include "preferences/constants.h" +#include "preferences/usersettings.h" +#include "util/screensaver.h" + +namespace mixxx { + +class ScreensaverManager : public QObject { + Q_OBJECT + public: + ScreensaverManager(UserSettingsPointer pConfig, QObject* pParent = nullptr); + ~ScreensaverManager(); + + void setStatus(mixxx::ScreenSaverPreference status); + + mixxx::ScreenSaverPreference status() { + return m_inhibitScreensaver; + } + public slots: + void slotCurrentPlayingDeckChanged(int deck); + + private: + const UserSettingsPointer m_pConfig; + mixxx::ScreenSaverPreference m_inhibitScreensaver; +}; + +} // namespace mixxx From b4e905519d95f2423bc7144fa401dc5ff366bd01 Mon Sep 17 00:00:00 2001 From: Jan Holthuis Date: Fri, 16 Jul 2021 11:59:49 +0200 Subject: [PATCH 05/25] DlgPrefInterface: Acquire primary screen for QGuiApplication We can't have any references to the `MixxxMainWindow` class in `DlgPrefInterface` if we want to use the preferences for QML skins that don't have a `MixxxMainWindow` instance. The using the primary screen is a sensible fallback. --- src/preferences/dialog/dlgprefinterface.cpp | 7 +++---- 1 file changed, 3 insertions(+), 4 deletions(-) diff --git a/src/preferences/dialog/dlgprefinterface.cpp b/src/preferences/dialog/dlgprefinterface.cpp index 3a1d62dc5c3..f4500912f4a 100644 --- a/src/preferences/dialog/dlgprefinterface.cpp +++ b/src/preferences/dialog/dlgprefinterface.cpp @@ -190,10 +190,9 @@ QScreen* DlgPrefInterface::getScreen() const { auto* pScreen = mixxx::widgethelper::getScreen(*this); if (!pScreen) { - // Obtain the screen from the main widget as a fallback. This - // is necessary if no window is available before the widget - // is displayed. - pScreen = mixxx::widgethelper::getScreen(*m_mixxx); + // Obtain the primary screen. This is necessary if no window is + // available before the widget is displayed. + pScreen = qGuiApp->primaryScreen(); } DEBUG_ASSERT(pScreen); return pScreen; From b0e0a32f0ddbafdf4f353c61ec27fb75f2eadffd Mon Sep 17 00:00:00 2001 From: Jan Holthuis Date: Fri, 16 Jul 2021 12:19:43 +0200 Subject: [PATCH 06/25] MixxxMainWindow: Move tooltip mode setting into preferences Instead of letting the `DlgPrefInterface` class hold a reference to the `MixxxMainWindow` and call its `setToolTipsCfg` method directly, we just update the config object and emit a signal that the main window can connect to. --- src/mixxxmainwindow.cpp | 9 +++--- src/mixxxmainwindow.h | 6 ++-- src/preferences/dialog/dlgpreferences.cpp | 15 ++++++---- src/preferences/dialog/dlgpreferences.h | 4 +++ src/preferences/dialog/dlgprefinterface.cpp | 31 ++++++++++++--------- src/preferences/dialog/dlgprefinterface.h | 3 ++ 6 files changed, 43 insertions(+), 25 deletions(-) diff --git a/src/mixxxmainwindow.cpp b/src/mixxxmainwindow.cpp index fe8baecceee..4090bf44d2e 100644 --- a/src/mixxxmainwindow.cpp +++ b/src/mixxxmainwindow.cpp @@ -232,6 +232,10 @@ MixxxMainWindow::MixxxMainWindow( m_pCoreServices->getLibrary()); m_pPrefDlg->setWindowIcon(QIcon(":/images/icons/mixxx.svg")); m_pPrefDlg->setHidden(true); + connect(m_pPrefDlg, + &DlgPreferences::tooltipModeChanged, + this, + &MixxxMainWindow::slotTooltipModeChanged); // Connect signals to the menubar. Should be done before emit newSkinLoaded. connectMenuBar(); @@ -986,10 +990,7 @@ void MixxxMainWindow::slotShowKeywheel(bool toggle) { } } -void MixxxMainWindow::setToolTipsCfg(mixxx::TooltipsPreference tt) { - UserSettingsPointer pConfig = m_pCoreServices->getSettings(); - pConfig->set(ConfigKey("[Controls]","Tooltips"), - ConfigValue(static_cast(tt))); +void MixxxMainWindow::slotTooltipModeChanged(mixxx::TooltipsPreference tt) { m_toolTipsCfg = tt; } diff --git a/src/mixxxmainwindow.h b/src/mixxxmainwindow.h index 38419bad9e6..d2adb8623f7 100644 --- a/src/mixxxmainwindow.h +++ b/src/mixxxmainwindow.h @@ -56,9 +56,6 @@ class MixxxMainWindow : public QMainWindow { void setInhibitScreensaver(mixxx::ScreenSaverPreference inhibit); mixxx::ScreenSaverPreference getInhibitScreensaver(); - void setToolTipsCfg(mixxx::TooltipsPreference tt); - inline mixxx::TooltipsPreference getToolTipsCfg() { return m_toolTipsCfg; } - inline GuiTick* getGuiTick() { return m_pGuiTick; }; public slots: @@ -85,6 +82,9 @@ class MixxxMainWindow : public QMainWindow { void slotNoDeckPassthroughInputConfigured(); void slotNoVinylControlInputConfigured(); + private slots: + void slotTooltipModeChanged(mixxx::TooltipsPreference tt); + signals: void skinLoaded(); /// used to uncheck the menu when the dialog of developer tools is closed diff --git a/src/preferences/dialog/dlgpreferences.cpp b/src/preferences/dialog/dlgpreferences.cpp index 61947724bf4..5c33734fffb 100644 --- a/src/preferences/dialog/dlgpreferences.cpp +++ b/src/preferences/dialog/dlgpreferences.cpp @@ -134,11 +134,16 @@ DlgPreferences::DlgPreferences( "ic_preferences_vinyl.svg"); #endif // __VINYLCONTROL__ - addPageWidget(PreferencesPage(new DlgPrefInterface(this, - mixxx, - pScreensaverManager, - pSkinLoader, - m_pConfig), + DlgPrefInterface* pInterfacePage = new DlgPrefInterface(this, + mixxx, + pScreensaverManager, + pSkinLoader, + m_pConfig); + connect(pInterfacePage, + &DlgPrefInterface::tooltipModeChanged, + this, + &DlgPreferences::tooltipModeChanged); + addPageWidget(PreferencesPage(pInterfacePage, new QTreeWidgetItem( contentsTreeWidget, QTreeWidgetItem::Type)), tr("Interface"), diff --git a/src/preferences/dialog/dlgpreferences.h b/src/preferences/dialog/dlgpreferences.h index e44646f48a2..0ada7cfa7cc 100644 --- a/src/preferences/dialog/dlgpreferences.h +++ b/src/preferences/dialog/dlgpreferences.h @@ -8,6 +8,7 @@ #include #include "control/controlpushbutton.h" +#include "preferences/constants.h" #include "preferences/dialog/dlgpreferencepage.h" #include "preferences/dialog/ui_dlgpreferencesdlg.h" #include "preferences/settingsmanager.h" @@ -106,6 +107,9 @@ class DlgPreferences : public QDialog, public Ui::DlgPreferencesDlg { // Emitted if the user clicks Reset to Defaults. void resetToDefaults(); + signals: + void tooltipModeChanged(mixxx::TooltipsPreference tooltipMode); + protected: bool eventFilter(QObject*, QEvent*); void moveEvent(QMoveEvent* e); diff --git a/src/preferences/dialog/dlgprefinterface.cpp b/src/preferences/dialog/dlgprefinterface.cpp index f4500912f4a..32980e01106 100644 --- a/src/preferences/dialog/dlgprefinterface.cpp +++ b/src/preferences/dialog/dlgprefinterface.cpp @@ -410,7 +410,9 @@ void DlgPrefInterface::slotApply() { m_pConfig->set(ConfigKey("[Config]", "StartInFullscreen"), ConfigValue(checkBoxStartFullScreen->isChecked())); - m_mixxx->setToolTipsCfg(m_tooltipMode); + m_pConfig->set(ConfigKey("[Controls]", "Tooltips"), + ConfigValue(static_cast(m_tooltipMode))); + emit tooltipModeChanged(m_tooltipMode); // screensaver mode update int screensaverComboBoxState = comboBoxScreensaver->itemData( @@ -436,17 +438,20 @@ void DlgPrefInterface::slotApply() { } void DlgPrefInterface::loadTooltipPreferenceFromConfig() { - mixxx::TooltipsPreference configTooltips = m_mixxx->getToolTipsCfg(); - switch (configTooltips) { - case mixxx::TooltipsPreference::TOOLTIPS_OFF: - radioButtonTooltipsOff->setChecked(true); - break; - case mixxx::TooltipsPreference::TOOLTIPS_ON: - radioButtonTooltipsLibraryAndSkin->setChecked(true); - break; - case mixxx::TooltipsPreference::TOOLTIPS_ONLY_IN_LIBRARY: - radioButtonTooltipsLibrary->setChecked(true); - break; + const auto tooltipMode = static_cast( + m_pConfig->getValue(ConfigKey("[Controls]", "Tooltips"), + static_cast(mixxx::TooltipsPreference::TOOLTIPS_ON))); + switch (tooltipMode) { + case mixxx::TooltipsPreference::TOOLTIPS_OFF: + radioButtonTooltipsOff->setChecked(true); + break; + case mixxx::TooltipsPreference::TOOLTIPS_ONLY_IN_LIBRARY: + radioButtonTooltipsLibrary->setChecked(true); + break; + case mixxx::TooltipsPreference::TOOLTIPS_ON: + default: + radioButtonTooltipsLibraryAndSkin->setChecked(true); + break; } - m_tooltipMode = configTooltips; + m_tooltipMode = tooltipMode; } diff --git a/src/preferences/dialog/dlgprefinterface.h b/src/preferences/dialog/dlgprefinterface.h index 4b54e2d951d..6392d39104f 100644 --- a/src/preferences/dialog/dlgprefinterface.h +++ b/src/preferences/dialog/dlgprefinterface.h @@ -50,6 +50,9 @@ class DlgPrefInterface : public DlgPreferencePage, public Ui::DlgPrefControlsDlg void slotSetScaleFactor(double newValue); void slotSetScaleFactorAuto(bool checked); + signals: + void tooltipModeChanged(mixxx::TooltipsPreference tooltipMode); + private: void notifyRebootNecessary(); void loadTooltipPreferenceFromConfig(); From ccf6bb22f6e0811f3464ee61d1958f077c7db2cf Mon Sep 17 00:00:00 2001 From: Jan Holthuis Date: Fri, 16 Jul 2021 12:47:13 +0200 Subject: [PATCH 07/25] DlgPreferences: Use signals to request skin reload Instead of calling `rebootMixxxView` directly, we can just emit a signal. This allows removing any references to the `MixxxMainWindow` in `DlgPreferences`. --- src/mixxxmainwindow.cpp | 5 +++++ src/preferences/dialog/dlgpreferences.cpp | 5 +++++ src/preferences/dialog/dlgpreferences.h | 1 + src/preferences/dialog/dlgprefinterface.cpp | 2 +- src/preferences/dialog/dlgprefinterface.h | 1 + 5 files changed, 13 insertions(+), 1 deletion(-) diff --git a/src/mixxxmainwindow.cpp b/src/mixxxmainwindow.cpp index 4090bf44d2e..994d94e45dc 100644 --- a/src/mixxxmainwindow.cpp +++ b/src/mixxxmainwindow.cpp @@ -236,6 +236,11 @@ MixxxMainWindow::MixxxMainWindow( &DlgPreferences::tooltipModeChanged, this, &MixxxMainWindow::slotTooltipModeChanged); + connect(m_pPrefDlg, + &DlgPreferences::reloadUserInterface, + this, + &MixxxMainWindow::rebootMixxxView, + Qt::DirectConnection); // Connect signals to the menubar. Should be done before emit newSkinLoaded. connectMenuBar(); diff --git a/src/preferences/dialog/dlgpreferences.cpp b/src/preferences/dialog/dlgpreferences.cpp index 5c33734fffb..a2651fc7111 100644 --- a/src/preferences/dialog/dlgpreferences.cpp +++ b/src/preferences/dialog/dlgpreferences.cpp @@ -143,6 +143,11 @@ DlgPreferences::DlgPreferences( &DlgPrefInterface::tooltipModeChanged, this, &DlgPreferences::tooltipModeChanged); + connect(pInterfacePage, + &DlgPrefInterface::reloadUserInterface, + this, + &DlgPreferences::reloadUserInterface, + Qt::DirectConnection); addPageWidget(PreferencesPage(pInterfacePage, new QTreeWidgetItem( contentsTreeWidget, QTreeWidgetItem::Type)), diff --git a/src/preferences/dialog/dlgpreferences.h b/src/preferences/dialog/dlgpreferences.h index 0ada7cfa7cc..361370fc902 100644 --- a/src/preferences/dialog/dlgpreferences.h +++ b/src/preferences/dialog/dlgpreferences.h @@ -108,6 +108,7 @@ class DlgPreferences : public QDialog, public Ui::DlgPreferencesDlg { void resetToDefaults(); signals: + void reloadUserInterface(); void tooltipModeChanged(mixxx::TooltipsPreference tooltipMode); protected: diff --git a/src/preferences/dialog/dlgprefinterface.cpp b/src/preferences/dialog/dlgprefinterface.cpp index 32980e01106..e11053b4a1f 100644 --- a/src/preferences/dialog/dlgprefinterface.cpp +++ b/src/preferences/dialog/dlgprefinterface.cpp @@ -430,7 +430,7 @@ void DlgPrefInterface::slotApply() { } if (m_bRebootMixxxView) { - m_mixxx->rebootMixxxView(); + emit reloadUserInterface(); // Allow switching skins multiple times without closing the dialog m_skinNameOnUpdate = m_pSkin->name(); } diff --git a/src/preferences/dialog/dlgprefinterface.h b/src/preferences/dialog/dlgprefinterface.h index 6392d39104f..5b8cdcf2f95 100644 --- a/src/preferences/dialog/dlgprefinterface.h +++ b/src/preferences/dialog/dlgprefinterface.h @@ -51,6 +51,7 @@ class DlgPrefInterface : public DlgPreferencePage, public Ui::DlgPrefControlsDlg void slotSetScaleFactorAuto(bool checked); signals: + void reloadUserInterface(); void tooltipModeChanged(mixxx::TooltipsPreference tooltipMode); private: From 405e165b48122c45baacbc0518a03a48dac80ced Mon Sep 17 00:00:00 2001 From: Jan Holthuis Date: Fri, 16 Jul 2021 13:00:04 +0200 Subject: [PATCH 08/25] DlgPrefWaveform: Use signal to request reload of user interface This is similar to the previous commit, it basically removes the necessity to hold a pointer to the main window. --- src/preferences/dialog/dlgpreferences.cpp | 8 +++++++- src/preferences/dialog/dlgprefwaveform.cpp | 2 +- src/preferences/dialog/dlgprefwaveform.h | 3 +++ 3 files changed, 11 insertions(+), 2 deletions(-) diff --git a/src/preferences/dialog/dlgpreferences.cpp b/src/preferences/dialog/dlgpreferences.cpp index a2651fc7111..9ef77f6c594 100644 --- a/src/preferences/dialog/dlgpreferences.cpp +++ b/src/preferences/dialog/dlgpreferences.cpp @@ -154,11 +154,17 @@ DlgPreferences::DlgPreferences( tr("Interface"), "ic_preferences_interface.svg"); + DlgPrefWaveform* pWaveformPage = new DlgPrefWaveform(this, mixxx, m_pConfig, pLibrary); addPageWidget(PreferencesPage( - new DlgPrefWaveform(this, mixxx, m_pConfig, pLibrary), + pWaveformPage, new QTreeWidgetItem(contentsTreeWidget, QTreeWidgetItem::Type)), tr("Waveforms"), "ic_preferences_waveforms.svg"); + connect(pWaveformPage, + &DlgPrefWaveform::reloadUserInterface, + this, + &DlgPreferences::reloadUserInterface, + Qt::DirectConnection); addPageWidget(PreferencesPage( new DlgPrefColors(this, m_pConfig, pLibrary), diff --git a/src/preferences/dialog/dlgprefwaveform.cpp b/src/preferences/dialog/dlgprefwaveform.cpp index 8be6f4ca4e0..8a17f4b2362 100644 --- a/src/preferences/dialog/dlgprefwaveform.cpp +++ b/src/preferences/dialog/dlgprefwaveform.cpp @@ -257,7 +257,7 @@ void DlgPrefWaveform::slotSetWaveformType(int index) { void DlgPrefWaveform::slotSetWaveformOverviewType(int index) { m_pConfig->set(ConfigKey("[Waveform]","WaveformOverviewType"), ConfigValue(index)); - m_pMixxx->rebootMixxxView(); + emit reloadUserInterface(); } void DlgPrefWaveform::slotSetDefaultZoom(int index) { diff --git a/src/preferences/dialog/dlgprefwaveform.h b/src/preferences/dialog/dlgprefwaveform.h index 66a488914a7..f4105dd6376 100644 --- a/src/preferences/dialog/dlgprefwaveform.h +++ b/src/preferences/dialog/dlgprefwaveform.h @@ -42,6 +42,9 @@ class DlgPrefWaveform : public DlgPreferencePage, public Ui::DlgPrefWaveformDlg void slotSetBeatGridAlpha(int alpha); void slotSetPlayMarkerPosition(int position); + signals: + void reloadUserInterface(); + private: void initWaveformControl(); void calculateCachedWaveformDiskUsage(); From f1a578004611058aa1884f32b6ed9c8e2dbc29f9 Mon Sep 17 00:00:00 2001 From: Jan Holthuis Date: Fri, 16 Jul 2021 13:01:36 +0200 Subject: [PATCH 09/25] DlgPreferences: Remove all references to MixxxMainWindow --- src/mixxxmainwindow.cpp | 1 - src/preferences/dialog/dlgpreferences.cpp | 4 +--- src/preferences/dialog/dlgpreferences.h | 3 +-- src/preferences/dialog/dlgprefinterface.cpp | 2 -- src/preferences/dialog/dlgprefinterface.h | 2 -- src/preferences/dialog/dlgprefwaveform.cpp | 4 +--- src/preferences/dialog/dlgprefwaveform.h | 3 --- 7 files changed, 3 insertions(+), 16 deletions(-) diff --git a/src/mixxxmainwindow.cpp b/src/mixxxmainwindow.cpp index 994d94e45dc..7d62fc83947 100644 --- a/src/mixxxmainwindow.cpp +++ b/src/mixxxmainwindow.cpp @@ -219,7 +219,6 @@ MixxxMainWindow::MixxxMainWindow( // Initialize preference dialog m_pPrefDlg = new DlgPreferences( - this, m_pCoreServices->getScreensaverManager(), m_pSkinLoader, m_pCoreServices->getSoundManager(), diff --git a/src/preferences/dialog/dlgpreferences.cpp b/src/preferences/dialog/dlgpreferences.cpp index 9ef77f6c594..d1b2fdcd357 100644 --- a/src/preferences/dialog/dlgpreferences.cpp +++ b/src/preferences/dialog/dlgpreferences.cpp @@ -52,7 +52,6 @@ #include "util/widgethelper.h" DlgPreferences::DlgPreferences( - MixxxMainWindow* mixxx, std::shared_ptr pScreensaverManager, std::shared_ptr pSkinLoader, std::shared_ptr pSoundManager, @@ -135,7 +134,6 @@ DlgPreferences::DlgPreferences( #endif // __VINYLCONTROL__ DlgPrefInterface* pInterfacePage = new DlgPrefInterface(this, - mixxx, pScreensaverManager, pSkinLoader, m_pConfig); @@ -154,7 +152,7 @@ DlgPreferences::DlgPreferences( tr("Interface"), "ic_preferences_interface.svg"); - DlgPrefWaveform* pWaveformPage = new DlgPrefWaveform(this, mixxx, m_pConfig, pLibrary); + DlgPrefWaveform* pWaveformPage = new DlgPrefWaveform(this, m_pConfig, pLibrary); addPageWidget(PreferencesPage( pWaveformPage, new QTreeWidgetItem(contentsTreeWidget, QTreeWidgetItem::Type)), diff --git a/src/preferences/dialog/dlgpreferences.h b/src/preferences/dialog/dlgpreferences.h index 361370fc902..d1c34b0acdd 100644 --- a/src/preferences/dialog/dlgpreferences.h +++ b/src/preferences/dialog/dlgpreferences.h @@ -14,7 +14,6 @@ #include "preferences/settingsmanager.h" #include "preferences/usersettings.h" -class MixxxMainWindow; class SoundManager; class DlgPrefSound; class DlgPrefLibrary; @@ -72,7 +71,7 @@ class DlgPreferences : public QDialog, public Ui::DlgPreferencesDlg { QTreeWidgetItem* pTreeItem; }; - DlgPreferences(MixxxMainWindow* mixxx, + DlgPreferences( std::shared_ptr pScreensaverManager, std::shared_ptr pSkinLoader, std::shared_ptr pSoundManager, diff --git a/src/preferences/dialog/dlgprefinterface.cpp b/src/preferences/dialog/dlgprefinterface.cpp index e11053b4a1f..d1b5cc3fa14 100644 --- a/src/preferences/dialog/dlgprefinterface.cpp +++ b/src/preferences/dialog/dlgprefinterface.cpp @@ -26,13 +26,11 @@ using mixxx::skin::SkinPointer; DlgPrefInterface::DlgPrefInterface( QWidget* parent, - MixxxMainWindow* mixxx, std::shared_ptr pScreensaverManager, std::shared_ptr pSkinLoader, UserSettingsPointer pConfig) : DlgPreferencePage(parent), m_pConfig(pConfig), - m_mixxx(mixxx), m_pScreensaverManager(pScreensaverManager), m_pSkinLoader(pSkinLoader), m_pSkin(pSkinLoader->getConfiguredSkin()), diff --git a/src/preferences/dialog/dlgprefinterface.h b/src/preferences/dialog/dlgprefinterface.h index 5b8cdcf2f95..a0663dd0b12 100644 --- a/src/preferences/dialog/dlgprefinterface.h +++ b/src/preferences/dialog/dlgprefinterface.h @@ -29,7 +29,6 @@ class DlgPrefInterface : public DlgPreferencePage, public Ui::DlgPrefControlsDlg public: DlgPrefInterface( QWidget* parent, - MixxxMainWindow* mixxx, std::shared_ptr pScreensaverManager, std::shared_ptr pSkinLoader, UserSettingsPointer pConfig); @@ -67,7 +66,6 @@ class DlgPrefInterface : public DlgPreferencePage, public Ui::DlgPrefControlsDlg UserSettingsPointer m_pConfig; ControlObject* m_pControlTrackTimeDisplay; - MixxxMainWindow *m_mixxx; std::shared_ptr m_pScreensaverManager; std::shared_ptr m_pSkinLoader; diff --git a/src/preferences/dialog/dlgprefwaveform.cpp b/src/preferences/dialog/dlgprefwaveform.cpp index 8a17f4b2362..00c43630c79 100644 --- a/src/preferences/dialog/dlgprefwaveform.cpp +++ b/src/preferences/dialog/dlgprefwaveform.cpp @@ -11,13 +11,11 @@ DlgPrefWaveform::DlgPrefWaveform( QWidget* pParent, - MixxxMainWindow* pMixxx, UserSettingsPointer pConfig, std::shared_ptr pLibrary) : DlgPreferencePage(pParent), m_pConfig(pConfig), - m_pLibrary(pLibrary), - m_pMixxx(pMixxx) { + m_pLibrary(pLibrary) { setupUi(this); // Waveform overview init diff --git a/src/preferences/dialog/dlgprefwaveform.h b/src/preferences/dialog/dlgprefwaveform.h index f4105dd6376..3f4a8ed43e3 100644 --- a/src/preferences/dialog/dlgprefwaveform.h +++ b/src/preferences/dialog/dlgprefwaveform.h @@ -7,7 +7,6 @@ #include "preferences/dialog/ui_dlgprefwaveformdlg.h" #include "preferences/usersettings.h" -class MixxxMainWindow; class Library; class DlgPrefWaveform : public DlgPreferencePage, public Ui::DlgPrefWaveformDlg { @@ -15,7 +14,6 @@ class DlgPrefWaveform : public DlgPreferencePage, public Ui::DlgPrefWaveformDlg public: DlgPrefWaveform( QWidget* pParent, - MixxxMainWindow* pMixxx, UserSettingsPointer pConfig, std::shared_ptr pLibrary); virtual ~DlgPrefWaveform(); @@ -52,5 +50,4 @@ class DlgPrefWaveform : public DlgPreferencePage, public Ui::DlgPrefWaveformDlg UserSettingsPointer m_pConfig; std::shared_ptr m_pLibrary; - MixxxMainWindow* m_pMixxx; }; From 1db2fd19845ba3700ab2842379d222ffa07cbb53 Mon Sep 17 00:00:00 2001 From: Be Date: Sat, 17 Jul 2021 18:12:04 -0500 Subject: [PATCH 10/25] CMake: only check for Upower if BATTERY=ON Upower might not be available on all systems: https://github.com/alpinelinux/aports/commit/27abfa3fd82ba63cfddd777c0ef9bd0145cd215a#r53627806 --- CMakeLists.txt | 13 ++++--------- 1 file changed, 4 insertions(+), 9 deletions(-) diff --git a/CMakeLists.txt b/CMakeLists.txt index b924921e418..e67b1f4b9d8 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -2188,15 +2188,6 @@ set(THREADS_PREFER_PTHREAD_FLAG ON) find_package(Threads REQUIRED) target_link_libraries(mixxx-lib PRIVATE Threads::Threads) -# Upower -if(UNIX AND NOT APPLE) - find_package(GLIB COMPONENTS gobject REQUIRED) - find_package(Upower REQUIRED) - target_include_directories(mixxx-lib SYSTEM PUBLIC ${GLIB_INCLUDE_DIRS}) - target_link_libraries(mixxx-lib PRIVATE ${GLIB_LIBRARIES} ${GLIB_GOBJECT_LIBRARIES}) - target_link_libraries(mixxx-lib PRIVATE Upower::Upower) -endif() - # iOS/OS X Frameworks if(APPLE) find_library(COREFOUNDATION_LIBRARY CoreFoundation REQUIRED) @@ -2232,6 +2223,10 @@ if(BATTERY) elseif(APPLE) target_sources(mixxx-lib PRIVATE src/util/battery/batterymac.cpp) elseif(UNIX) + find_package(Upower REQUIRED) + find_package(GLIB COMPONENTS gobject REQUIRED) + target_include_directories(mixxx-lib SYSTEM PUBLIC ${GLIB_INCLUDE_DIRS}) + target_link_libraries(mixxx-lib PRIVATE Upower::Upower ${GLIB_LIBRARIES} ${GLIB_GOBJECT_LIBRARIES}) target_sources(mixxx-lib PRIVATE src/util/battery/batterylinux.cpp) else() message(FATAL_ERROR "Battery support is not implemented for the target platform.") From f68df505cddf3674c7e8bd78d200dda7ccb97aed Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Daniel=20Sch=C3=BCrmann?= Date: Mon, 19 Jul 2021 00:05:31 +0200 Subject: [PATCH 11/25] removed unused pConfig parameter --- src/controllers/midi/hss1394controller.cpp | 3 +-- src/controllers/midi/hss1394controller.h | 3 +-- src/controllers/midi/hss1394enumerator.cpp | 2 +- 3 files changed, 3 insertions(+), 5 deletions(-) diff --git a/src/controllers/midi/hss1394controller.cpp b/src/controllers/midi/hss1394controller.cpp index fb6efda3e4f..95fd45ab676 100644 --- a/src/controllers/midi/hss1394controller.cpp +++ b/src/controllers/midi/hss1394controller.cpp @@ -59,8 +59,7 @@ void DeviceChannelListener::Reconnected() { Hss1394Controller::Hss1394Controller( const hss1394::TNodeInfo& deviceInfo, - int deviceIndex, - UserSettingsPointer pConfig) + int deviceIndex) : MidiController(), m_deviceInfo(deviceInfo), m_iDeviceIndex(deviceIndex) { diff --git a/src/controllers/midi/hss1394controller.h b/src/controllers/midi/hss1394controller.h index 1f1cbf57e55..cbf6929eb52 100644 --- a/src/controllers/midi/hss1394controller.h +++ b/src/controllers/midi/hss1394controller.h @@ -39,8 +39,7 @@ class Hss1394Controller : public MidiController { public: Hss1394Controller( const hss1394::TNodeInfo& deviceInfo, - int deviceIndex, - UserSettingsPointer pConfig); + int deviceIndex); ~Hss1394Controller() override; private slots: diff --git a/src/controllers/midi/hss1394enumerator.cpp b/src/controllers/midi/hss1394enumerator.cpp index 76a120c9701..d8a4d539972 100644 --- a/src/controllers/midi/hss1394enumerator.cpp +++ b/src/controllers/midi/hss1394enumerator.cpp @@ -41,7 +41,7 @@ QList Hss1394Enumerator::queryDevices() { QString("%1").arg(tNodeInfo.uProtocolVersion, 0, 16)); qDebug() << " " << message; Hss1394Controller* currentDevice = new Hss1394Controller( - tNodeInfo, i, m_pConfig); + tNodeInfo, i); m_devices.push_back(currentDevice); } } From 8337216a01d6f2d092e5ed6de29a5061c56de326 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Daniel=20Sch=C3=BCrmann?= Date: Mon, 19 Jul 2021 00:53:06 +0200 Subject: [PATCH 12/25] added missing cast to remove "unsafe mix of type" warning --- src/engine/sync/synccontrol.cpp | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/engine/sync/synccontrol.cpp b/src/engine/sync/synccontrol.cpp index e01f75640f5..5762a03dd79 100644 --- a/src/engine/sync/synccontrol.cpp +++ b/src/engine/sync/synccontrol.cpp @@ -474,7 +474,7 @@ void SyncControl::updateAudible() { if (channelIndex >= 0) { CSAMPLE_GAIN gain = getEngineMaster()->getMasterGain(channelIndex); bool newAudible = gain > CSAMPLE_GAIN_ZERO; - if (m_audible != newAudible) { + if (static_cast(m_audible) != newAudible) { m_audible = newAudible; m_pEngineSync->notifyPlayingAudible(this, m_pPlayButton->toBool() && m_audible); } From 687ce5f9d9da995f18ce724b335a325b76cc371e Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Daniel=20Sch=C3=BCrmann?= Date: Mon, 19 Jul 2021 01:01:06 +0200 Subject: [PATCH 13/25] fix size warning --- src/widget/wtracktableviewheader.cpp | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/widget/wtracktableviewheader.cpp b/src/widget/wtracktableviewheader.cpp index a79ecc30530..fae519c629e 100644 --- a/src/widget/wtracktableviewheader.cpp +++ b/src/widget/wtracktableviewheader.cpp @@ -49,7 +49,7 @@ HeaderViewState::HeaderViewState(const QString& base64serialized) { QString HeaderViewState::saveState() const { // Serialize the proto to a byte array, then encode the array as Base64. #if GOOGLE_PROTOBUF_VERSION >= 3001000 - size_t size = m_view_state.ByteSizeLong(); + int size = static_cast(m_view_state.ByteSizeLong()); #else int size = m_view_state.ByteSize(); #endif From 432af75895e6f5471ab38e4b6a716d3278a341d3 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Daniel=20Sch=C3=BCrmann?= Date: Mon, 19 Jul 2021 01:02:59 +0200 Subject: [PATCH 14/25] fix unused warning --- src/library/export/dlglibraryexport.cpp | 1 + 1 file changed, 1 insertion(+) diff --git a/src/library/export/dlglibraryexport.cpp b/src/library/export/dlglibraryexport.cpp index ded3eac4f6b..9b0e6eff5f6 100644 --- a/src/library/export/dlglibraryexport.cpp +++ b/src/library/export/dlglibraryexport.cpp @@ -273,6 +273,7 @@ void DlgLibraryExport::checkExistingDatabase() { } } catch (std::exception& e) { + Q_UNUSED(e); m_pExistingDatabaseLabel->setText( tr("A database already exists in the chosen directory, " "but there was a problem loading it. Export is not " From 217691491fcf9d9656c085180e4a78810e0683b7 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Daniel=20Sch=C3=BCrmann?= Date: Mon, 19 Jul 2021 01:07:49 +0200 Subject: [PATCH 15/25] fix type warning --- src/encoder/encoderopus.cpp | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/encoder/encoderopus.cpp b/src/encoder/encoderopus.cpp index d8e2632d9d0..46fa95d8934 100644 --- a/src/encoder/encoderopus.cpp +++ b/src/encoder/encoderopus.cpp @@ -287,7 +287,7 @@ void EncoderOpus::pushTagsPacket() { int commentCount = 0; const char* vendorString = opus_get_version_string(); - int vendorStringLength = strlen(vendorString); + int vendorStringLength = static_cast(strlen(vendorString)); // == Compute tags frame size == // - Magic signature: 8 bytes From 9d8256d6c3218470c2b70c6fbd7e3b9d15dbcd74 Mon Sep 17 00:00:00 2001 From: Be Date: Mon, 19 Jul 2021 15:44:24 -0500 Subject: [PATCH 16/25] CMake: also search for libusb as 'usb' library without '-1.0' This is required to locate libusb on FreeBSD. --- cmake/modules/FindLibUSB.cmake | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/cmake/modules/FindLibUSB.cmake b/cmake/modules/FindLibUSB.cmake index 7a309ade16b..91737f9c0ca 100644 --- a/cmake/modules/FindLibUSB.cmake +++ b/cmake/modules/FindLibUSB.cmake @@ -57,7 +57,7 @@ find_path(LibUSB_INCLUDE_DIR mark_as_advanced(LibUSB_INCLUDE_DIR) find_library(LibUSB_LIBRARY - NAMES usb-1.0 + NAMES usb-1.0 usb PATHS ${PC_LibUSB_LIBRARY_DIRS} DOC "LibUSB library" ) From 3c7f810c6eb260cbe53390674364f75c218d3608 Mon Sep 17 00:00:00 2001 From: Be Date: Mon, 19 Jul 2021 15:50:05 -0500 Subject: [PATCH 17/25] SPSCQueue: include BSD in hack around LLVM bug --- lib/rigtorp/SPSCQueue/include/rigtorp/SPSCQueue.h | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/lib/rigtorp/SPSCQueue/include/rigtorp/SPSCQueue.h b/lib/rigtorp/SPSCQueue/include/rigtorp/SPSCQueue.h index d09f0d3f10f..33b87a05bf5 100644 --- a/lib/rigtorp/SPSCQueue/include/rigtorp/SPSCQueue.h +++ b/lib/rigtorp/SPSCQueue/include/rigtorp/SPSCQueue.h @@ -189,7 +189,7 @@ template > class SPSCQueue { // on macOS there is a bug in libc++ where __cpp_lib_hardware_interference_size // is defined but std::hardware_destructive_interference_size is not actually implemented // https://bugs.llvm.org/show_bug.cgi?id=41423 -#if defined(__cpp_lib_hardware_interference_size) && ! defined(__APPLE__) +#if defined(__cpp_lib_hardware_interference_size) && ! defined(__APPLE__) && ! defined(__BSD__) static constexpr size_t kCacheLineSize = std::hardware_destructive_interference_size; #else From f1411c7876548b2fe6962a22eba64ecad0210b94 Mon Sep 17 00:00:00 2001 From: Be Date: Mon, 19 Jul 2021 15:53:12 -0500 Subject: [PATCH 18/25] VersionStore: add BSDs to platform string --- src/util/versionstore.cpp | 5 +++++ 1 file changed, 5 insertions(+) diff --git a/src/util/versionstore.cpp b/src/util/versionstore.cpp index 0abae4bbbfe..7e255ac13b0 100644 --- a/src/util/versionstore.cpp +++ b/src/util/versionstore.cpp @@ -77,6 +77,11 @@ QString VersionStore::platform() { QString base = QStringLiteral("Linux"); #elif defined(__WINDOWS__) QString base = QStringLiteral("Windows"); +// Mixxx's CMakeLists.txt does not define this, but FreeBSD's ports system does. +#elif defined(__FREEBSD__) + QString base = QStringLiteral("FreeBSD"); +#elif defined(__BSD__) + QString base = QStringLiteral("BSD"); #else QString base = QStringLiteral("Unknown OS"); #endif From 0cdf85c9b611b7041d861428d0e8d8ec9f01a8ec Mon Sep 17 00:00:00 2001 From: Jan Holthuis Date: Tue, 20 Jul 2021 13:02:18 +0200 Subject: [PATCH 19/25] BeatGrid: Fix wrong multiplication with kFrameSize The beatgrid now uses frames, so this multiplication results in a beatgrid of half the intended BPM. This was an oversight from #4049. --- src/track/beatgrid.cpp | 9 ++++----- 1 file changed, 4 insertions(+), 5 deletions(-) diff --git a/src/track/beatgrid.cpp b/src/track/beatgrid.cpp index a50f4ea4bb3..5d3376418f2 100644 --- a/src/track/beatgrid.cpp +++ b/src/track/beatgrid.cpp @@ -14,7 +14,6 @@ struct BeatGridData { double firstBeat; }; -constexpr int kFrameSize = 2; constexpr double kBpmScaleRounding = 0.001; } // namespace @@ -349,8 +348,8 @@ BeatsPointer BeatGrid::scale(BpmScale scale) const { bpm = BeatUtils::roundBpmWithinRange(bpm - kBpmScaleRounding, bpm, bpm + kBpmScaleRounding); grid.mutable_bpm()->set_bpm(bpm.value()); - double beatLength = (60.0 * m_sampleRate / bpm.value()) * kFrameSize; - return BeatsPointer(new BeatGrid(*this, grid, beatLength)); + const mixxx::audio::FrameDiff_t beatLengthFrames = (60.0 * m_sampleRate / bpm.value()); + return BeatsPointer(new BeatGrid(*this, grid, beatLengthFrames)); } BeatsPointer BeatGrid::setBpm(mixxx::Bpm bpm) { @@ -359,8 +358,8 @@ BeatsPointer BeatGrid::setBpm(mixxx::Bpm bpm) { } mixxx::track::io::BeatGrid grid = m_grid; grid.mutable_bpm()->set_bpm(bpm.value()); - double beatLength = (60.0 * m_sampleRate / bpm.value()) * kFrameSize; - return BeatsPointer(new BeatGrid(*this, grid, beatLength)); + const mixxx::audio::FrameDiff_t beatLengthFrames = (60.0 * m_sampleRate / bpm.value()); + return BeatsPointer(new BeatGrid(*this, grid, beatLengthFrames)); } } // namespace mixxx From 7b23500f929e2e2435c3af963ed05bd0138b6586 Mon Sep 17 00:00:00 2001 From: Jan Holthuis Date: Tue, 20 Jul 2021 23:38:40 +0200 Subject: [PATCH 20/25] SoundSourceFFmpeg: Fix assignment in debug assertion --- src/sources/soundsourceffmpeg.cpp | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/src/sources/soundsourceffmpeg.cpp b/src/sources/soundsourceffmpeg.cpp index 4729191764c..70319ce1cdd 100644 --- a/src/sources/soundsourceffmpeg.cpp +++ b/src/sources/soundsourceffmpeg.cpp @@ -968,9 +968,9 @@ const CSAMPLE* SoundSourceFFmpeg::resampleDecodedAVFrame() { #if VERBOSE_DEBUG_LOG avTrace("Received resampled frame", *m_pavResampledFrame); #endif - DEBUG_ASSERT(m_pavDecodedFrame->pts = m_pavResampledFrame->pts); - DEBUG_ASSERT(m_pavDecodedFrame->nb_samples = - m_pavResampledFrame->nb_samples); + DEBUG_ASSERT(m_pavDecodedFrame->pts == m_pavResampledFrame->pts); + DEBUG_ASSERT(m_pavDecodedFrame->nb_samples == + m_pavResampledFrame->nb_samples); return reinterpret_cast( m_pavResampledFrame->extended_data[0]); } else { From 1005e8e15f9172d9bf1db2c0ed70df2a2e693367 Mon Sep 17 00:00:00 2001 From: Jan Holthuis Date: Tue, 20 Jul 2021 23:41:39 +0200 Subject: [PATCH 21/25] FwdSqlQuery: Use static assert instead of runtime DEBUG_ASSERT --- src/util/db/fwdsqlquery.cpp | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/util/db/fwdsqlquery.cpp b/src/util/db/fwdsqlquery.cpp index d3b0467475b..7c8e5ea8838 100644 --- a/src/util/db/fwdsqlquery.cpp +++ b/src/util/db/fwdsqlquery.cpp @@ -121,7 +121,7 @@ inline bool boolFromQVariantInt(const QVariant& variant) { << value; } // C-style conversion from int to bool - DEBUG_ASSERT(kBooleanFalse == 0); + static_assert(kBooleanFalse == 0); return value != kBooleanFalse; } From 7c2b106865ee659a7b80bec3b0b1713326ef6407 Mon Sep 17 00:00:00 2001 From: Jan Holthuis Date: Tue, 20 Jul 2021 23:40:45 +0200 Subject: [PATCH 22/25] Add some missing includes --- src/controllers/scripting/colormapperjsproxy.cpp | 3 +++ src/controllers/scripting/colormapperjsproxy.h | 1 + src/engine/enginesidechaincompressor.h | 1 + src/soundio/soundmanagerutil.h | 7 ++++--- src/track/replaygain.h | 1 + src/util/compatibility.h | 1 + src/util/db/fwdsqlquery.h | 2 ++ 7 files changed, 13 insertions(+), 3 deletions(-) diff --git a/src/controllers/scripting/colormapperjsproxy.cpp b/src/controllers/scripting/colormapperjsproxy.cpp index 582bb2aa372..e06d58bff52 100644 --- a/src/controllers/scripting/colormapperjsproxy.cpp +++ b/src/controllers/scripting/colormapperjsproxy.cpp @@ -1,5 +1,8 @@ #include "controllers/scripting/colormapperjsproxy.h" +#include +#include + #include "moc_colormapperjsproxy.cpp" ColorMapperJSProxy::ColorMapperJSProxy(const QVariantMap& availableColors) diff --git a/src/controllers/scripting/colormapperjsproxy.h b/src/controllers/scripting/colormapperjsproxy.h index 8b6cd79c423..3b742c463ab 100644 --- a/src/controllers/scripting/colormapperjsproxy.h +++ b/src/controllers/scripting/colormapperjsproxy.h @@ -1,5 +1,6 @@ #pragma once #include +#include #include #include "controllers/scripting/colormapper.h" diff --git a/src/engine/enginesidechaincompressor.h b/src/engine/enginesidechaincompressor.h index bc7d030c652..251049e5bb3 100644 --- a/src/engine/enginesidechaincompressor.h +++ b/src/engine/enginesidechaincompressor.h @@ -1,4 +1,5 @@ #pragma once +#include #include "util/types.h" diff --git a/src/soundio/soundmanagerutil.h b/src/soundio/soundmanagerutil.h index 7e5e5032a7b..dddb140795a 100644 --- a/src/soundio/soundmanagerutil.h +++ b/src/soundio/soundmanagerutil.h @@ -1,12 +1,13 @@ #pragma once -#include -#include #include #include +#include +#include +#include -#include "util/types.h" #include "util/fifo.h" +#include "util/types.h" /// Describes a group of channels, typically a pair for stereo sound in Mixxx. class ChannelGroup { diff --git a/src/track/replaygain.h b/src/track/replaygain.h index 9c943e828cc..76c3e51fa52 100644 --- a/src/track/replaygain.h +++ b/src/track/replaygain.h @@ -1,4 +1,5 @@ #pragma once +#include #include "util/types.h" diff --git a/src/util/compatibility.h b/src/util/compatibility.h index ce64c6db6bf..e1648b3b9d9 100644 --- a/src/util/compatibility.h +++ b/src/util/compatibility.h @@ -6,6 +6,7 @@ #include #include #include +#include #include "util/assert.h" diff --git a/src/util/db/fwdsqlquery.h b/src/util/db/fwdsqlquery.h index fc273198a21..c03aef77967 100644 --- a/src/util/db/fwdsqlquery.h +++ b/src/util/db/fwdsqlquery.h @@ -3,6 +3,8 @@ #include #include #include +#include +#include #include "util/assert.h" #include "util/db/dbfieldindex.h" From 04d1b3cef442133933d3bab7e3510acd6f5b0fe7 Mon Sep 17 00:00:00 2001 From: Uwe Klotz Date: Wed, 21 Jul 2021 11:04:47 +0200 Subject: [PATCH 23/25] SoundSourceFFmpeg: Fix debug assertions --- src/sources/soundsourceffmpeg.cpp | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/src/sources/soundsourceffmpeg.cpp b/src/sources/soundsourceffmpeg.cpp index 70319ce1cdd..d76851f5856 100644 --- a/src/sources/soundsourceffmpeg.cpp +++ b/src/sources/soundsourceffmpeg.cpp @@ -968,9 +968,9 @@ const CSAMPLE* SoundSourceFFmpeg::resampleDecodedAVFrame() { #if VERBOSE_DEBUG_LOG avTrace("Received resampled frame", *m_pavResampledFrame); #endif - DEBUG_ASSERT(m_pavDecodedFrame->pts == m_pavResampledFrame->pts); - DEBUG_ASSERT(m_pavDecodedFrame->nb_samples == - m_pavResampledFrame->nb_samples); + DEBUG_ASSERT(m_pavResampledFrame->pts == AV_NOPTS_VALUE || + m_pavResampledFrame->pts == m_pavDecodedFrame->pts); + DEBUG_ASSERT(m_pavResampledFrame->nb_samples == m_pavDecodedFrame->nb_samples); return reinterpret_cast( m_pavResampledFrame->extended_data[0]); } else { From 57fc273d7590d025f205ac9912f199155f924880 Mon Sep 17 00:00:00 2001 From: ronso0 Date: Wed, 21 Jul 2021 16:29:45 +0200 Subject: [PATCH 24/25] PaleMoon: fix AddRandomTrack button style --- res/skins/LateNight/style_palemoon.qss | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/res/skins/LateNight/style_palemoon.qss b/res/skins/LateNight/style_palemoon.qss index e75bdd5beff..89af38d25e6 100644 --- a/res/skins/LateNight/style_palemoon.qss +++ b/res/skins/LateNight/style_palemoon.qss @@ -2444,7 +2444,7 @@ QPushButton#pushButtonShuffle:enabled { image: url(skin:/palemoon/buttons/btn__autodj_shuffle.svg) no-repeat center center; } -QPushButton#pushButtonAddRandom:enabled { +QPushButton#pushButtonAddRandomTrack:enabled { image: url(skin:/palemoon/buttons/btn__autodj_addrandom.svg) no-repeat center center; } From 0fb764a0e97c660b853f944ddfc2ea04d0243317 Mon Sep 17 00:00:00 2001 From: Jan Holthuis Date: Thu, 22 Jul 2021 22:38:03 +0200 Subject: [PATCH 25/25] Merge pull request #3921 from ywwg/syncleader Squashed commit of the following: commit 6a50c70a18268bc83b5549d43e31d197cbe4cc18 Merge: 805beb7848 ac7daeb08f Author: Owen Williams Date: Tue Jul 20 22:55:05 2021 -0400 Merge branch 'main' into syncleader commit 805beb78480ac8c99af21a3dba0ab44040c2b84f Author: Owen Williams Date: Tue Jul 20 10:08:16 2021 -0400 Sync Lock: missed a conversion to "leader" commit 23942eead3613e51642e068d3b4222a323deef0a Author: Owen Williams Date: Mon Jul 19 14:20:30 2021 -0400 Sync Lock: Update remaining instances of "master" Remove sync_mode from control picker menu, it's an internal CO that should not need to be mapped. commit 6fbf69a4beb867df39ab63bf30c1cc5a1596b323 Merge: eb76915bfd 36781b101b Author: Owen Williams Date: Mon Jul 19 14:12:06 2021 -0400 Merge branch 'syncleader' commit 36781b101b2fb66671bc960a08bd909822a7bc8e Merge: e79703d030 3ef395bf0b Author: Owen Williams Date: Sat Jul 10 10:07:09 2021 -0400 Merge branch 'main' into syncleader commit e79703d0305e4b31bc40ae7e02814fe5b7a1d0dc Author: Owen Williams Date: Sat Jul 10 09:57:49 2021 -0400 Sync Lock: convert enums to enum classes commit 8559d2f317201a1ed06de912511e7d58f6866e27 Author: Owen Williams Date: Fri Jul 9 15:32:18 2021 -0400 Sync Lock: rename a few more instances of sync_master to sync_leader commit 9f374f400b1de4b355cebfc4d39ba0676a7bda38 Merge: 9e857968c4 422912bd46 Author: Owen Williams Date: Fri Jul 9 15:25:26 2021 -0400 Merge branch 'main' into syncleader commit 9e857968c4fbeee2b114f16fff3d1064752af15b Author: Owen Williams Date: Fri May 28 16:34:16 2021 -0400 Rename Sync instances of "master" to "leader" Also add an alias from the sync_master CO to sync_leader commit 2d2b485c648e39223e0eaa36b85125148f696010 Author: Owen Williams Date: Tue Jun 15 22:21:04 2021 -0400 Sync Lock: Don't recalc half/double multiplier on every callback commit fa980d97f37da09a1508ccdbaba0fe700ffe2afc Author: Owen Williams Date: Mon Mar 15 15:51:51 2021 -0400 Sync Lock: rename functions to make them clearer --- res/controllers/American Audio VMS4.midi.xml | 16 +- .../Hercules DJ Control MP3 e2-scripts.js | 4 +- .../Hercules DJControl Starlight.midi.xml | 8 +- .../Hercules_DJControl_Inpulse_200.midi.xml | 8 +- .../Hercules_DJControl_Inpulse_300.midi.xml | 8 +- .../Hercules_DJControl_Jogvision.midi.xml | 8 +- .../Novation-Launchpad MK2-scripts.js | 8 +- res/controllers/Novation-Launchpad-scripts.js | 8 +- res/controllers/Roland_DJ-505-scripts.js | 4 +- .../Traktor-Kontrol-S4-MK2-hid-scripts.js | 6 +- res/skins/LateNight/decks/rate_controls.xml | 6 +- src/controllers/controlpickermenu.cpp | 54 +- src/engine/controls/bpmcontrol.cpp | 12 +- src/engine/controls/bpmcontrol.h | 4 +- src/engine/controls/ratecontrol.cpp | 6 +- src/engine/controls/ratecontrol.h | 2 +- src/engine/enginebuffer.cpp | 27 +- src/engine/enginebuffer.h | 2 +- src/engine/enginemaster.cpp | 6 +- src/engine/enginemaster.h | 4 +- src/engine/sync/clock.h | 4 +- src/engine/sync/enginesync.cpp | 246 +++--- src/engine/sync/enginesync.h | 74 +- src/engine/sync/internalclock.cpp | 66 +- src/engine/sync/internalclock.h | 18 +- src/engine/sync/syncable.h | 108 +-- src/engine/sync/synccontrol.cpp | 150 ++-- src/engine/sync/synccontrol.h | 24 +- src/mixer/basetrackplayer.cpp | 2 +- src/skin/legacy/tooltips.cpp | 12 +- src/test/co_dumps/co_dump_inital.csv | 20 +- src/test/enginesynctest.cpp | 748 +++++++++--------- src/test/synccontroltest.cpp | 4 +- 33 files changed, 863 insertions(+), 814 deletions(-) diff --git a/res/controllers/American Audio VMS4.midi.xml b/res/controllers/American Audio VMS4.midi.xml index c1593bdb471..750b47533a9 100644 --- a/res/controllers/American Audio VMS4.midi.xml +++ b/res/controllers/American Audio VMS4.midi.xml @@ -3,7 +3,7 @@ American Audio VMS4/4.1 Anders Gunnarsson & Sean M. Pappalardo - 2-deck control/4-deck mixer preset for Mixxx 2.1. + 2-deck control/4-deck mixer preset for Mixxx 2.1. Assumes "Post EQ" mode. (See Wiki for full setup instructions.) american_audio_vms4 @@ -295,13 +295,13 @@ Assumes "Post EQ" mode. (See Wiki for full setup instructions.) [Channel1] - sync_master + sync_leader 0x91 0x0D [Channel1] - sync_master + sync_leader 0x81 0x0D @@ -1000,13 +1000,13 @@ Assumes "Post EQ" mode. (See Wiki for full setup instructions.) [Channel2] - sync_master + sync_leader 0x91 0x2F [Channel2] - sync_master + sync_leader 0x81 0x2F @@ -1615,7 +1615,7 @@ Assumes "Post EQ" mode. (See Wiki for full setup instructions.) - + [Channel3] @@ -1671,7 +1671,7 @@ Assumes "Post EQ" mode. (See Wiki for full setup instructions.) - + [Channel4] @@ -1727,7 +1727,7 @@ Assumes "Post EQ" mode. (See Wiki for full setup instructions.) - + diff --git a/res/controllers/Hercules DJ Control MP3 e2-scripts.js b/res/controllers/Hercules DJ Control MP3 e2-scripts.js index a019e21604d..745d5bbabe3 100644 --- a/res/controllers/Hercules DJ Control MP3 e2-scripts.js +++ b/res/controllers/Hercules DJ Control MP3 e2-scripts.js @@ -731,7 +731,7 @@ HerculesMP3e2.jogWheel = function(midino, control, value, status, group) { // drive master tempo led connected to sync_mode HerculesMP3e2.syncmode = function(value, group, control) { - // Following code was used for sync_master control. + // Following code was used for sync_leader control. // Deactivated for now due to https://bugs.launchpad.net/mixxx/+bug/1456801 // currently (2015-05-20) explicit master mode is not supported. // Switched to sync_enabled (binary) control @@ -1004,4 +1004,4 @@ HerculesMP3e2.filterMid = function(midino, control, value, status, group) { HerculesMP3e2.filterLow = function(midino, control, value, status, group) { HerculesMP3e2.filterKnob(group, "parameter1", value); -}; \ No newline at end of file +}; diff --git a/res/controllers/Hercules DJControl Starlight.midi.xml b/res/controllers/Hercules DJControl Starlight.midi.xml index a33e8e83259..78b8cd0a5ca 100644 --- a/res/controllers/Hercules DJControl Starlight.midi.xml +++ b/res/controllers/Hercules DJControl Starlight.midi.xml @@ -202,7 +202,7 @@ // Sync [Channel1] - sync_master + sync_leader SHIFT + Sync: Sync Master 0x94 0x05 @@ -266,7 +266,7 @@ // Sync [Channel2] - sync_master + sync_leader SHIFT + Sync: Sync Master 0x95 0x05 @@ -1082,7 +1082,7 @@ [Channel1] - sync_master + sync_leader SYNC LED Deck A(SHIFT mode) 0.5 1 @@ -1130,7 +1130,7 @@ [Channel2] - sync_master + sync_leader SYNC LED Deck B(SHIFT mode) 0.5 1 diff --git a/res/controllers/Hercules_DJControl_Inpulse_200.midi.xml b/res/controllers/Hercules_DJControl_Inpulse_200.midi.xml index d9d36d6b143..79ac80305f8 100644 --- a/res/controllers/Hercules_DJControl_Inpulse_200.midi.xml +++ b/res/controllers/Hercules_DJControl_Inpulse_200.midi.xml @@ -283,7 +283,7 @@ [Channel1] - sync_master + sync_leader SHIFT + Sync: Sync Master 0x94 0x05 @@ -349,7 +349,7 @@ [Channel2] - sync_master + sync_leader SHIFT + Sync: Sync Master 0x95 0x05 @@ -1181,7 +1181,7 @@ [Channel1] - sync_master + sync_leader SYNC LED Deck A(SHIFT mode) 0.5 1 @@ -1225,7 +1225,7 @@ [Channel2] - sync_master + sync_leader SYNC LED Deck B(SHIFT mode) 0.5 1 diff --git a/res/controllers/Hercules_DJControl_Inpulse_300.midi.xml b/res/controllers/Hercules_DJControl_Inpulse_300.midi.xml index 840582ea61b..ed31dcfb0fe 100644 --- a/res/controllers/Hercules_DJControl_Inpulse_300.midi.xml +++ b/res/controllers/Hercules_DJControl_Inpulse_300.midi.xml @@ -364,7 +364,7 @@ [Channel1] - sync_master + sync_leader SHIFT + Sync: Sync Master 0x94 0x05 @@ -443,7 +443,7 @@ [Channel2] - sync_master + sync_leader SHIFT + Sync: Sync Master 0x95 0x05 @@ -1693,7 +1693,7 @@ [Channel1] - sync_master + sync_leader SYNC LED Deck A(SHIFT mode) 0.5 1 @@ -1759,7 +1759,7 @@ [Channel2] - sync_master + sync_leader SYNC LED Deck B(SHIFT mode) 0.5 1 diff --git a/res/controllers/Hercules_DJControl_Jogvision.midi.xml b/res/controllers/Hercules_DJControl_Jogvision.midi.xml index d7723cd3b5a..1f7aa166a8d 100644 --- a/res/controllers/Hercules_DJControl_Jogvision.midi.xml +++ b/res/controllers/Hercules_DJControl_Jogvision.midi.xml @@ -110,7 +110,7 @@ [Channel1] - sync_master + sync_leader SHIFT + Sync: Sync Master 0x90 0x35 @@ -594,7 +594,7 @@ [Channel2] - sync_master + sync_leader SHIFT + Sync: Sync Master 0x91 0x35 @@ -1473,7 +1473,7 @@ [Channel1] - sync_master + sync_leader SYNC LED Deck A(SHIFT mode) 0.5 1 @@ -1550,7 +1550,7 @@ [Channel2] - sync_master + sync_leader SYNC LED Deck A(SHIFT mode) 0.5 1 diff --git a/res/controllers/Novation-Launchpad MK2-scripts.js b/res/controllers/Novation-Launchpad MK2-scripts.js index bcfc1eff159..a201965e3d4 100644 --- a/res/controllers/Novation-Launchpad MK2-scripts.js +++ b/res/controllers/Novation-Launchpad MK2-scripts.js @@ -2202,9 +2202,9 @@ var NovationLaunchpadMK2 = (function () { name: 'sync_enabled', type: 'binary' }, - sync_master: { + sync_leader: { group: "[".concat(type).concat(i, "]"), - name: 'sync_master', + name: 'sync_leader', type: 'binary' }, sync_mode: { @@ -6765,9 +6765,9 @@ var NovationLaunchpadMK2 = (function () { } }, function () { if (bindings.syncMode.getValue() === 2) { - deck.sync_master.setValue(0); + deck.sync_leader.setValue(0); } else { - deck.sync_master.setValue(1); + deck.sync_leader.setValue(1); } }); } diff --git a/res/controllers/Novation-Launchpad-scripts.js b/res/controllers/Novation-Launchpad-scripts.js index 6817fd5d074..16ef464ef68 100644 --- a/res/controllers/Novation-Launchpad-scripts.js +++ b/res/controllers/Novation-Launchpad-scripts.js @@ -2202,9 +2202,9 @@ var NovationLaunchpad = (function () { name: 'sync_enabled', type: 'binary' }, - sync_master: { + sync_leader: { group: "[".concat(type).concat(i, "]"), - name: 'sync_master', + name: 'sync_leader', type: 'binary' }, sync_mode: { @@ -6765,9 +6765,9 @@ var NovationLaunchpad = (function () { } }, function () { if (bindings.syncMode.getValue() === 2) { - deck.sync_master.setValue(0); + deck.sync_leader.setValue(0); } else { - deck.sync_master.setValue(1); + deck.sync_leader.setValue(1); } }); } diff --git a/res/controllers/Roland_DJ-505-scripts.js b/res/controllers/Roland_DJ-505-scripts.js index c1ed44d10e9..f08f568d32b 100644 --- a/res/controllers/Roland_DJ-505-scripts.js +++ b/res/controllers/Roland_DJ-505-scripts.js @@ -629,8 +629,8 @@ DJ505.Deck = function(deckNumbers, offset) { // If already explicit leader, reset explicit state // (setting it to 0 may still make it implicit leader and // immediately resetting it to 1). - var value = (engine.getValue(this.group, "sync_master") === 2) ? 0 : 2; - engine.setValue(this.group, "sync_master", value); + var value = (engine.getValue(this.group, "sync_leader") === 2) ? 0 : 2; + engine.setValue(this.group, "sync_leader", value); } else { engine.setValue(this.group, "sync_enabled", 1); } diff --git a/res/controllers/Traktor-Kontrol-S4-MK2-hid-scripts.js b/res/controllers/Traktor-Kontrol-S4-MK2-hid-scripts.js index 1a92241b694..cf3109867d5 100644 --- a/res/controllers/Traktor-Kontrol-S4-MK2-hid-scripts.js +++ b/res/controllers/Traktor-Kontrol-S4-MK2-hid-scripts.js @@ -380,7 +380,7 @@ TraktorS4MK2.registerOutputPackets = function() { Output1.addOutput("[Master]", "!usblight", 0x2A, "B"); Output1.addOutput("[Master]", "!quantize", 0x31, "B"); - Output1.addOutput("[InternalClock]", "sync_master", 0x30, "B"); + Output1.addOutput("[InternalClock]", "sync_leader", 0x30, "B"); Output1.addOutput("[Recording]", "status", 0x34, "B"); this.controller.registerOutputPacket(Output1); @@ -550,7 +550,7 @@ TraktorS4MK2.registerOutputPackets = function() { TraktorS4MK2.linkChannelOutput("[EffectRack1_EffectUnit2_Effect3]", "enabled", TraktorS4MK2.outputChannelCallback); TraktorS4MK2.linkChannelOutput("[PreviewDeck1]", "play_indicator", TraktorS4MK2.outputChannelCallback); - TraktorS4MK2.linkChannelOutput("[InternalClock]", "sync_master", TraktorS4MK2.outputChannelCallback); + TraktorS4MK2.linkChannelOutput("[InternalClock]", "sync_leader", TraktorS4MK2.outputChannelCallback); if (TraktorS4MK2.RemixSlotButtonAction === "SAMPLES") { TraktorS4MK2.linkChannelOutput("[Sampler1]", "play_indicator", TraktorS4MK2.outputChannelCallback); @@ -723,7 +723,7 @@ TraktorS4MK2.init = function(id) { TraktorS4MK2.controller.setOutput("[Master]", "!usblight", 0x7F, true); - TraktorS4MK2.outputChannelCallback(engine.getValue("[InternalClock]", "sync_master"), "[InternalClock]", "sync_master"); + TraktorS4MK2.outputChannelCallback(engine.getValue("[InternalClock]", "sync_leader"), "[InternalClock]", "sync_leader"); TraktorS4MK2.outputChannelCallback(engine.getValue("[Recording]", "status"), "[Recording]", "status"); TraktorS4MK2.controller.setOutput("deck1", "!on_air", engine.getValue("[Recording]", "status")*0x7F); TraktorS4MK2.controller.setOutput("deck2", "!on_air", engine.getValue("[Recording]", "status")*0x7F); diff --git a/res/skins/LateNight/decks/rate_controls.xml b/res/skins/LateNight/decks/rate_controls.xml index 1f81ad23f12..4a67fc600b8 100644 --- a/res/skins/LateNight/decks/rate_controls.xml +++ b/res/skins/LateNight/decks/rate_controls.xml @@ -80,10 +80,10 @@ 48f,22f sync ,sync_enabled - ,sync_master + ,sync_leader - sync_master + sync_leader SyncLeader 48f,22f 3 @@ -103,7 +103,7 @@ skin://buttons/btn__sync_active.svg - ,sync_master + ,sync_leader LeftButton diff --git a/src/controllers/controlpickermenu.cpp b/src/controllers/controlpickermenu.cpp index 1d99b08a0c1..8bc5d6fb6e9 100644 --- a/src/controllers/controlpickermenu.cpp +++ b/src/controllers/controlpickermenu.cpp @@ -224,24 +224,44 @@ ControlPickerMenu::ControlPickerMenu(QWidget* pParent) tr("One-time beat sync (phase only)"), syncMenu); syncMenu->addSeparator(); - addControl("[InternalClock]", "sync_master", tr("Internal Sync Master"), - tr("Toggle Internal Sync Master"), syncMenu); - addControl("[InternalClock]", "bpm", tr("Internal Master BPM"), - tr("Internal Master BPM"), syncMenu); - addControl("[InternalClock]", "bpm_up", tr("Internal Master BPM +1"), - tr("Increase internal master BPM by 1"), syncMenu); - - addControl("[InternalClock]", "bpm_down", tr("Internal Master BPM -1"), - tr("Decrease internal master BPM by 1"), syncMenu); - - addControl("[InternalClock]", "bpm_up_small", tr("Internal Master BPM +0.1"), - tr("Increase internal master BPM by 0.1"), syncMenu); - addControl("[InternalClock]", "bpm_down_small", tr("Internal Master BPM -0.1"), - tr("Decrease internal master BPM by 0.1"), syncMenu); + addControl("[InternalClock]", + "sync_leader", + tr("Internal Sync Leader"), + tr("Toggle Internal Sync Leader"), + syncMenu); + addControl("[InternalClock]", + "bpm", + tr("Internal Leader BPM"), + tr("Internal Leader BPM"), + syncMenu); + addControl("[InternalClock]", + "bpm_up", + tr("Internal Leader BPM +1"), + tr("Increase internal Leader BPM by 1"), + syncMenu); + + addControl("[InternalClock]", + "bpm_down", + tr("Internal Leader BPM -1"), + tr("Decrease internal Leader BPM by 1"), + syncMenu); + + addControl("[InternalClock]", + "bpm_up_small", + tr("Internal Leader BPM +0.1"), + tr("Increase internal Leader BPM by 0.1"), + syncMenu); + addControl("[InternalClock]", + "bpm_down_small", + tr("Internal Leader BPM -0.1"), + tr("Decrease internal Leader BPM by 0.1"), + syncMenu); syncMenu->addSeparator(); - addDeckAndSamplerControl("sync_master", tr("Sync Master"), tr("Toggle sync master"), syncMenu); - addDeckAndSamplerControl("sync_mode", tr("Sync Mode"), - tr("Sync mode 3-state toggle (OFF, FOLLOWER, MASTER)"), syncMenu); + addDeckAndSamplerControl("sync_leader", + tr("Sync Leader"), + tr("Sync mode 3-state toggle / indicator (Off, Soft Leader, " + "Explicit Leader)"), + syncMenu); // Speed QMenu* speedMenu = addSubmenu(tr("Speed")); diff --git a/src/engine/controls/bpmcontrol.cpp b/src/engine/controls/bpmcontrol.cpp index 2a3a76a045f..05aafdb4049 100644 --- a/src/engine/controls/bpmcontrol.cpp +++ b/src/engine/controls/bpmcontrol.cpp @@ -302,7 +302,7 @@ void BpmControl::slotControlBeatSync(double value) { } bool BpmControl::syncTempo() { - if (getSyncMode() == SYNC_MASTER_EXPLICIT) { + if (getSyncMode() == SyncMode::LeaderExplicit) { return false; } EngineBuffer* pOtherEngineBuffer = pickSyncTarget(); @@ -419,7 +419,7 @@ double BpmControl::calcSyncedRate(double userTweak) { rate = m_dSyncInstantaneousBpm / m_pLocalBpm->get(); } - // If we are not quantized, or there are no beats, or we're master, + // If we are not quantized, or there are no beats, or we're leader, // or we're in reverse, just return the rate as-is. if (!m_pQuantize->toBool() || !m_pBeats || m_pReverseButton->toBool()) { m_resetSyncAdjustment = true; @@ -458,10 +458,10 @@ double BpmControl::calcSyncAdjustment(bool userTweakingSync) { m_dLastSyncAdjustment = 1.0; } - // Either shortest distance is directly to the master or backwards. + // Either shortest distance is directly to the leader or backwards. // TODO(rryan): This is kind of backwards because we are measuring distance - // from master to my percentage. All of the control code below is based on + // from leader to my percentage. All of the control code below is based on // this point of reference so I left it this way but I think we should think // about things in terms of "my percentage-offset setpoint" that the control // loop should aim to maintain. @@ -478,7 +478,7 @@ double BpmControl::calcSyncAdjustment(bool userTweakingSync) { if (kLogger.traceEnabled()) { kLogger.trace() << m_group << "****************"; - kLogger.trace() << "master beat distance:" << syncTargetBeatDistance; + kLogger.trace() << "target beat distance:" << syncTargetBeatDistance; kLogger.trace() << "my beat distance:" << thisBeatDistance; kLogger.trace() << "user offset distance:" << curUserOffset; kLogger.trace() << "error :" << error; @@ -1063,7 +1063,7 @@ void BpmControl::slotBeatsTranslateMatchAlignment(double v) { const mixxx::BeatsPointer pBeats = pTrack->getBeats(); if (pBeats) { // Must reset the user offset *before* calling getPhaseOffset(), - // otherwise it will always return 0 if master sync is active. + // otherwise it will always return 0 if sync lock is active. m_dUserOffset.setValue(0.0); double sampleOffset = getPhaseOffset(getSampleOfTrack().current); diff --git a/src/engine/controls/bpmcontrol.h b/src/engine/controls/bpmcontrol.h index d178683e0bd..248a6ddc07a 100644 --- a/src/engine/controls/bpmcontrol.h +++ b/src/engine/controls/bpmcontrol.h @@ -30,7 +30,7 @@ class BpmControl : public EngineControl { return m_pLocalBpm ? mixxx::Bpm(m_pLocalBpm->get()) : mixxx::Bpm(); } - // When in master sync mode, ratecontrol calls calcSyncedRate to figure out + // When in sync lock mode, ratecontrol calls calcSyncedRate to figure out // how fast the track should play back. The returned rate is usually just // the correct pitch to match bpms. The usertweak argument represents // how much the user is nudging the pitch to get two tracks into sync, and @@ -176,5 +176,5 @@ class BpmControl : public EngineControl { mixxx::BeatsPointer m_pBeats; FRIEND_TEST(EngineSyncTest, UserTweakPreservedInSeek); - FRIEND_TEST(EngineSyncTest, FollowerUserTweakPreservedInMasterChange); + FRIEND_TEST(EngineSyncTest, FollowerUserTweakPreservedInLeaderChange); }; diff --git a/src/engine/controls/ratecontrol.cpp b/src/engine/controls/ratecontrol.cpp index 2e27cf2d057..b84f7759a95 100644 --- a/src/engine/controls/ratecontrol.cpp +++ b/src/engine/controls/ratecontrol.cpp @@ -57,7 +57,7 @@ RateControl::RateControl(const QString& group, this, &RateControl::slotRateRangeChanged, Qt::DirectConnection); - // Allow rate slider to go out of bounds so that master sync rate + // Allow rate slider to go out of bounds so that sync lock rate // adjustments are not capped. m_pRateSlider = new ControlPotmeter( ConfigKey(group, "rate"), -1.0, 1.0, true); @@ -461,11 +461,11 @@ double RateControl::calculateSpeed(double baserate, double speed, bool paused, rate = m_pScratchController->getRate(); *pReportScratching = true; } else { - // If master sync is on, respond to it -- but vinyl and scratch mode always override. + // If sync lock is on, respond to it -- but vinyl and scratch mode always override. if (toSynchronized(getSyncMode()) && !paused && !bVinylControlEnabled && !useScratch2Value) { if (m_pBpmControl == nullptr) { - qDebug() << "ERROR: calculateRate m_pBpmControl is null during master sync"; + qDebug() << "ERROR: calculateRate m_pBpmControl is null during sync lock"; return 1.0; } diff --git a/src/engine/controls/ratecontrol.h b/src/engine/controls/ratecontrol.h index 54accae3e03..efd2e7fce1e 100644 --- a/src/engine/controls/ratecontrol.h +++ b/src/engine/controls/ratecontrol.h @@ -143,7 +143,7 @@ public slots: ControlObject* m_pSampleRate; - // For Master Sync + // For Sync Lock BpmControl* m_pBpmControl; ControlProxy* m_pSyncMode; diff --git a/src/engine/enginebuffer.cpp b/src/engine/enginebuffer.cpp index 94629768aff..408f0094153 100644 --- a/src/engine/enginebuffer.cpp +++ b/src/engine/enginebuffer.cpp @@ -88,7 +88,7 @@ EngineBuffer::EngineBuffer(const QString& group, m_bScalerOverride(false), m_iSeekPhaseQueued(0), m_iEnableSyncQueued(SYNC_REQUEST_NONE), - m_iSyncModeQueued(SYNC_INVALID), + m_iSyncModeQueued(static_cast(SyncMode::Invalid)), m_iTrackLoading(0), m_bPlayAfterLoading(false), m_pCrossfadeBuffer(SampleUtil::alloc(MAX_BUFFER_LEN)), @@ -404,9 +404,9 @@ void EngineBuffer::requestEnableSync(bool enabled) { // If we're not playing, the queued event won't get processed so do it now. if (m_playButton->get() == 0.0) { if (enabled) { - m_pEngineSync->requestSyncMode(m_pSyncControl, SYNC_FOLLOWER); + m_pEngineSync->requestSyncMode(m_pSyncControl, SyncMode::Follower); } else { - m_pEngineSync->requestSyncMode(m_pSyncControl, SYNC_NONE); + m_pEngineSync->requestSyncMode(m_pSyncControl, SyncMode::None); } return; } @@ -437,7 +437,7 @@ void EngineBuffer::requestSyncMode(SyncMode mode) { if (m_playButton->get() == 0.0) { m_pEngineSync->requestSyncMode(m_pSyncControl, mode); } else { - m_iSyncModeQueued = mode; + m_iSyncModeQueued = static_cast(mode); } } @@ -1168,7 +1168,7 @@ void EngineBuffer::process(CSAMPLE* pOutput, const int iBufferSize) { } #endif - if (isMaster(m_pSyncControl->getSyncMode())) { + if (isLeader(m_pSyncControl->getSyncMode())) { // Report our speed to SyncControl immediately instead of waiting // for postProcess so we can broadcast this update to followers. m_pSyncControl->reportPlayerSpeed(m_speed_old, m_scratching_old); @@ -1206,22 +1206,23 @@ void EngineBuffer::processSyncRequests() { static_cast( m_iEnableSyncQueued.fetchAndStoreRelease(SYNC_REQUEST_NONE)); SyncMode mode_request = - static_cast(m_iSyncModeQueued.fetchAndStoreRelease(SYNC_INVALID)); + static_cast(m_iSyncModeQueued.fetchAndStoreRelease( + static_cast(SyncMode::Invalid))); switch (enable_request) { case SYNC_REQUEST_ENABLE: - m_pEngineSync->requestSyncMode(m_pSyncControl, SYNC_FOLLOWER); + m_pEngineSync->requestSyncMode(m_pSyncControl, SyncMode::Follower); break; case SYNC_REQUEST_DISABLE: - m_pEngineSync->requestSyncMode(m_pSyncControl, SYNC_NONE); + m_pEngineSync->requestSyncMode(m_pSyncControl, SyncMode::None); break; case SYNC_REQUEST_ENABLEDISABLE: - m_pEngineSync->requestSyncMode(m_pSyncControl, SYNC_FOLLOWER); - m_pEngineSync->requestSyncMode(m_pSyncControl, SYNC_NONE); + m_pEngineSync->requestSyncMode(m_pSyncControl, SyncMode::Follower); + m_pEngineSync->requestSyncMode(m_pSyncControl, SyncMode::None); break; case SYNC_REQUEST_NONE: break; } - if (mode_request != SYNC_INVALID) { + if (mode_request != SyncMode::Invalid) { m_pEngineSync->requestSyncMode(m_pSyncControl, static_cast(mode_request)); } @@ -1321,10 +1322,10 @@ void EngineBuffer::postProcess(const int iBufferSize) { m_pSyncControl->setLocalBpm(localBpmValue); m_pSyncControl->updateAudible(); SyncMode mode = m_pSyncControl->getSyncMode(); - if (isMaster(mode)) { + if (isLeader(mode)) { m_pEngineSync->notifyBeatDistanceChanged(m_pSyncControl, beatDistance); } else if (isFollower(mode)) { - // Report our speed to SyncControl. If we are master, we already did this. + // Report our speed to SyncControl. If we are leader, we already did this. m_pSyncControl->reportPlayerSpeed(m_speed_old, m_scratching_old); m_pSyncControl->updateTargetBeatDistance(); } diff --git a/src/engine/enginebuffer.h b/src/engine/enginebuffer.h index 0d9d8868f65..75f66a0b369 100644 --- a/src/engine/enginebuffer.h +++ b/src/engine/enginebuffer.h @@ -260,7 +260,7 @@ class EngineBuffer : public EngineObject { FRIEND_TEST(EngineSyncTest, HalfDoubleThenPlay); FRIEND_TEST(EngineSyncTest, UserTweakBeatDistance); FRIEND_TEST(EngineSyncTest, UserTweakPreservedInSeek); - FRIEND_TEST(EngineSyncTest, FollowerUserTweakPreservedInMasterChange); + FRIEND_TEST(EngineSyncTest, FollowerUserTweakPreservedInLeaderChange); FRIEND_TEST(EngineSyncTest, BeatMapQuantizePlay); FRIEND_TEST(EngineBufferTest, ScalerNoTransport); EngineSync* m_pEngineSync; diff --git a/src/engine/enginemaster.cpp b/src/engine/enginemaster.cpp index fc6260bddd7..34cb9d22e86 100644 --- a/src/engine/enginemaster.cpp +++ b/src/engine/enginemaster.cpp @@ -270,7 +270,7 @@ const CSAMPLE* EngineMaster::getSidechainBuffer() const { } void EngineMaster::processChannels(int iBufferSize) { - // Update internal master sync rate. + // Update internal sync lock rate. m_pMasterSync->onCallbackStart(m_iSampleRate, m_iBufferSize); m_activeBusChannels[EngineChannel::LEFT].clear(); @@ -281,7 +281,7 @@ void EngineMaster::processChannels(int iBufferSize) { m_activeChannels.clear(); //ScopedTimer timer("EngineMaster::processChannels"); - EngineChannel* pMasterChannel = m_pMasterSync->getMaster(); + EngineChannel* pMasterChannel = m_pMasterSync->getLeader(); // Reserve the first place for the master channel which // should be processed first m_activeChannels.append(NULL); @@ -367,7 +367,7 @@ void EngineMaster::processChannels(int iBufferSize) { } } - // Do internal master sync post-processing before the other + // Do internal sync lock post-processing before the other // channels. // Note, because we call this on the internal clock first, // it will have an up-to-date beatDistance, whereas the other diff --git a/src/engine/enginemaster.h b/src/engine/enginemaster.h index eed8ee0fa45..f85af0b11c1 100644 --- a/src/engine/enginemaster.h +++ b/src/engine/enginemaster.h @@ -87,7 +87,7 @@ class EngineMaster : public QObject, public AudioSource { } } - // Provide access to the master sync so enginebuffers can know what their rate controller is. + // Provide access to the sync lock so enginebuffers can know what their rate controller is. EngineSync* getEngineSync() const{ return m_pMasterSync; } @@ -254,7 +254,7 @@ class EngineMaster : public QObject, public AudioSource { ControlObject* m_pBoothEnabled; private: - // Processes active channels. The master sync channel (if any) is processed + // Processes active channels. The sync lock channel (if any) is processed // first and all others are processed after. Populates m_activeChannels, // m_activeBusChannels, m_activeHeadphoneChannels, and // m_activeTalkoverChannels with each channel that is active for the diff --git a/src/engine/sync/clock.h b/src/engine/sync/clock.h index 9814bf1d441..a0e8731fe51 100644 --- a/src/engine/sync/clock.h +++ b/src/engine/sync/clock.h @@ -5,8 +5,8 @@ class Clock { virtual ~Clock() = default; virtual double getBeatDistance() const = 0; - virtual void updateMasterBeatDistance(double beatDistance) = 0; + virtual void updateLeaderBeatDistance(double beatDistance) = 0; virtual double getBpm() const = 0; - virtual void updateMasterBpm(double bpm) = 0; + virtual void updateLeaderBpm(double bpm) = 0; }; diff --git a/src/engine/sync/enginesync.cpp b/src/engine/sync/enginesync.cpp index 3b7c83eb2cc..7b8faf9b9c6 100644 --- a/src/engine/sync/enginesync.cpp +++ b/src/engine/sync/enginesync.cpp @@ -17,9 +17,9 @@ const QString kInternalClockGroup = QStringLiteral("[InternalClock]"); EngineSync::EngineSync(UserSettingsPointer pConfig) : m_pConfig(pConfig), m_pInternalClock(new InternalClock(kInternalClockGroup, this)), - m_pMasterSyncable(nullptr) { + m_pLeaderSyncable(nullptr) { qRegisterMetaType("SyncMode"); - m_pInternalClock->updateMasterBpm(124.0); + m_pInternalClock->updateLeaderBpm(124.0); } EngineSync::~EngineSync() { @@ -41,32 +41,32 @@ void EngineSync::requestSyncMode(Syncable* pSyncable, SyncMode mode) { // the pSyncable's new mode (it may not be the one they requested), // and activating the appropriate modes in it as well as possibly other // decks that need to change as a result. - Syncable* oldMaster = m_pMasterSyncable; + Syncable* oldLeader = m_pLeaderSyncable; switch (mode) { - case SYNC_MASTER_EXPLICIT: - case SYNC_MASTER_SOFT: { + case SyncMode::LeaderExplicit: + case SyncMode::LeaderSoft: { if (pSyncable->getBaseBpm() > 0) { - activateMaster(pSyncable, mode); + activateLeader(pSyncable, mode); } else { - // Because we don't have a valid bpm, we can't be the master + // Because we don't have a valid bpm, we can't be the leader // (or else everyone would try to be syncing to zero bpm). // Override and make us a follower instead. activateFollower(pSyncable); } break; } - case SYNC_FOLLOWER: { + case SyncMode::Follower: { // A request for follower mode may be converted into an enabling of soft - // master mode. + // leader mode. activateFollower(pSyncable); - Syncable* newMaster = pickMaster(pSyncable); - if (newMaster && newMaster != m_pMasterSyncable) { - // if the master has changed, activate it (this updates m_pMasterSyncable) - activateMaster(newMaster, SYNC_MASTER_SOFT); + Syncable* newLeader = pickLeader(pSyncable); + if (newLeader && newLeader != m_pLeaderSyncable) { + // if the leader has changed, activate it (this updates m_pLeaderSyncable) + activateLeader(newLeader, SyncMode::LeaderSoft); } break; } - case SYNC_NONE: { + case SyncMode::None: { if (pSyncable != m_pInternalClock) { deactivateSync(pSyncable); } @@ -82,26 +82,27 @@ void EngineSync::requestSyncMode(Syncable* pSyncable, SyncMode mode) { pOnlyPlayer->notifyUniquePlaying(); } - // Second, figure out what Syncable should be used to initialize the master - // parameters, if any. Usually this is the new master. (Note, that pointer might be null!) - Syncable* pParamsSyncable = m_pMasterSyncable; - // But If we are newly soft master, we need to match to some other deck. - if (pSyncable == m_pMasterSyncable && pSyncable != oldMaster && mode != SYNC_MASTER_EXPLICIT) { + // Second, figure out what Syncable should be used to initialize the leader + // parameters, if any. Usually this is the new leader. (Note, that pointer might be null!) + Syncable* pParamsSyncable = m_pLeaderSyncable; + // But If we are newly soft leader, we need to match to some other deck. + if (pSyncable == m_pLeaderSyncable && pSyncable != oldLeader && + mode != SyncMode::LeaderExplicit) { pParamsSyncable = findBpmMatchTarget(pSyncable); if (!pParamsSyncable) { // We weren't able to find anything to match to, so set ourselves as the - // target. That way we'll use our own params when we updateMasterBpm below. + // target. That way we'll use our own params when we updateLeaderParams below. pParamsSyncable = pSyncable; } } - // Now that all of the decks have their assignments, reinit master params if needed. + // Now that all of the decks have their assignments, reinit leader params if needed. if (pParamsSyncable) { if (kLogger.traceEnabled()) { kLogger.trace() - << "EngineSync::requestSyncMode setting master params from " + << "EngineSync::requestSyncMode setting leader params from " << pParamsSyncable->getGroup(); } - reinitMasterParams(pParamsSyncable); + reinitLeaderParams(pParamsSyncable); pSyncable->updateInstantaneousBpm(pParamsSyncable->getBpm()); if (pParamsSyncable != pSyncable) { pSyncable->requestSync(); @@ -120,47 +121,48 @@ void EngineSync::activateFollower(Syncable* pSyncable) { << pSyncable->getGroup(); } - if (m_pMasterSyncable == pSyncable) { - m_pMasterSyncable = nullptr; + if (m_pLeaderSyncable == pSyncable) { + m_pLeaderSyncable = nullptr; } - pSyncable->setSyncMode(SYNC_FOLLOWER); + pSyncable->setSyncMode(SyncMode::Follower); } -void EngineSync::activateMaster(Syncable* pSyncable, SyncMode masterType) { +void EngineSync::activateLeader(Syncable* pSyncable, SyncMode leaderType) { VERIFY_OR_DEBUG_ASSERT(pSyncable) { - qWarning() << "WARNING: Logic Error: Called activateMaster on a nullptr Syncable."; + qWarning() << "WARNING: Logic Error: Called activateLeader on a nullptr Syncable."; return; } - VERIFY_OR_DEBUG_ASSERT(masterType == SYNC_MASTER_SOFT || masterType == SYNC_MASTER_EXPLICIT) { - qWarning() << "WARNING: Logic Error: Called activateMaster with non-master mode"; + VERIFY_OR_DEBUG_ASSERT(leaderType == SyncMode::LeaderSoft || + leaderType == SyncMode::LeaderExplicit) { + qWarning() << "WARNING: Logic Error: Called activateLeader with non-leader mode"; } if (kLogger.traceEnabled()) { - kLogger.trace() << "EngineSync::activateMaster: " + kLogger.trace() << "EngineSync::activateLeader: " << pSyncable->getGroup() << "type: " - << masterType; + << leaderType; } - if (m_pMasterSyncable == pSyncable) { - // Already master, update the master type. - if (m_pMasterSyncable->getSyncMode() != masterType) { - m_pMasterSyncable->setSyncMode(masterType); + if (m_pLeaderSyncable == pSyncable) { + // Already leader, update the leader type. + if (m_pLeaderSyncable->getSyncMode() != leaderType) { + m_pLeaderSyncable->setSyncMode(leaderType); } // nothing else to do return; } - // If a different channel is already master, disable it. - Syncable* pOldChannelMaster = m_pMasterSyncable; - m_pMasterSyncable = nullptr; - if (pOldChannelMaster) { - pOldChannelMaster->setSyncMode(SYNC_FOLLOWER); + // If a different channel is already leader, disable it. + Syncable* pOldChannelLeader = m_pLeaderSyncable; + m_pLeaderSyncable = nullptr; + if (pOldChannelLeader) { + pOldChannelLeader->setSyncMode(SyncMode::Follower); } - m_pMasterSyncable = pSyncable; - pSyncable->setSyncMode(masterType); + m_pLeaderSyncable = pSyncable; + pSyncable->setSyncMode(leaderType); - if (m_pMasterSyncable != m_pInternalClock) { + if (m_pLeaderSyncable != m_pInternalClock) { // the internal clock gets activated and its values are overwritten with this // new deck. activateFollower(m_pInternalClock); @@ -174,38 +176,38 @@ void EngineSync::deactivateSync(Syncable* pSyncable) { if (kLogger.traceEnabled()) { kLogger.trace() << "EngineSync::deactivateSync" << pSyncable->getGroup(); } - bool wasMaster = isSyncMaster(pSyncable); - if (wasMaster) { - m_pMasterSyncable = nullptr; + bool wasLeader = isSyncLeader(pSyncable); + if (wasLeader) { + m_pLeaderSyncable = nullptr; } // Notifications happen after-the-fact. - pSyncable->setSyncMode(SYNC_NONE); + pSyncable->setSyncMode(SyncMode::None); bool bSyncDeckExists = syncDeckExists(); if (pSyncable != m_pInternalClock && !bSyncDeckExists) { // Deactivate the internal clock if there are no more sync decks left. - m_pMasterSyncable = nullptr; - m_pInternalClock->setSyncMode(SYNC_NONE); + m_pLeaderSyncable = nullptr; + m_pInternalClock->setSyncMode(SyncMode::None); return; } - if (wasMaster) { - Syncable* newMaster = pickMaster(nullptr); - if (newMaster != nullptr) { - activateMaster(newMaster, SYNC_MASTER_SOFT); + if (wasLeader) { + Syncable* newLeader = pickLeader(nullptr); + if (newLeader != nullptr) { + activateLeader(newLeader, SyncMode::LeaderSoft); } } } -Syncable* EngineSync::pickMaster(Syncable* enabling_syncable) { +Syncable* EngineSync::pickLeader(Syncable* enabling_syncable) { if (kLogger.traceEnabled()) { - kLogger.trace() << "EngineSync::pickMaster"; + kLogger.trace() << "EngineSync::pickLeader"; } - if (m_pMasterSyncable && - m_pMasterSyncable->getSyncMode() == SYNC_MASTER_EXPLICIT && - m_pMasterSyncable->getBaseBpm() != 0.0) { - return m_pMasterSyncable; + if (m_pLeaderSyncable && + m_pLeaderSyncable->getSyncMode() == SyncMode::LeaderExplicit && + m_pLeaderSyncable->getBaseBpm() != 0.0) { + return m_pLeaderSyncable; } // First preference: some other sync deck that is not playing. @@ -252,10 +254,10 @@ Syncable* EngineSync::pickMaster(Syncable* enabling_syncable) { const SyncLockAlgorithm picker = static_cast( m_pConfig->getValue(ConfigKey("[BPM]", "sync_lock_algorithm"), - PREFER_IMPLICIT_MASTER)); + PREFER_IMPLICIT_LEADER)); switch (picker) { - case PREFER_IMPLICIT_MASTER: - // Always pick a deck for a new master. + case PREFER_IMPLICIT_LEADER: + // Always pick a deck for a new leader. if (playing_deck_count == 1) { return first_playing_deck; } else if (playing_deck_count > 1) { @@ -300,7 +302,7 @@ Syncable* EngineSync::findBpmMatchTarget(Syncable* requester) { if (pOtherSyncable == requester) { continue; } - // Skip non-master decks, like preview decks. + // Skip non-leader decks, like preview decks. if (!pOtherSyncable->getChannel()->isMasterEnabled()) { continue; } @@ -357,19 +359,19 @@ void EngineSync::notifyPlayingAudible(Syncable* pSyncable, bool playingAudible) return; } - // similar to enablesync -- we pick a new master and maybe reinit. - Syncable* newMaster = pickMaster(pSyncable); + // similar to enablesync -- we pick a new leader and maybe reinit. + Syncable* newLeader = pickLeader(pSyncable); - if (newMaster != nullptr && newMaster != m_pMasterSyncable) { - activateMaster(newMaster, SYNC_MASTER_SOFT); - reinitMasterParams(newMaster); + if (newLeader != nullptr && newLeader != m_pLeaderSyncable) { + activateLeader(newLeader, SyncMode::LeaderSoft); + reinitLeaderParams(newLeader); } else { Syncable* pOnlyPlayer = getUniquePlayingSyncedDeck(); if (pOnlyPlayer) { - // Even if we didn't change master, if there is only one player (us), then we should + // Even if we didn't change leader, if there is only one player (us), then we should // update the beat distance. pOnlyPlayer->notifyUniquePlaying(); - updateMasterBeatDistance(pOnlyPlayer, pOnlyPlayer->getBeatDistance()); + updateLeaderBeatDistance(pOnlyPlayer, pOnlyPlayer->getBeatDistance()); } } @@ -387,8 +389,8 @@ void EngineSync::notifyBaseBpmChanged(Syncable* pSyncable, double bpm) { kLogger.trace() << "EngineSync::notifyBaseBpmChanged" << pSyncable->getGroup() << bpm; } - if (isSyncMaster(pSyncable)) { - updateMasterBpm(pSyncable, bpm); + if (isSyncLeader(pSyncable)) { + updateLeaderBpm(pSyncable, bpm); } } @@ -397,7 +399,7 @@ void EngineSync::notifyRateChanged(Syncable* pSyncable, double bpm) { kLogger.trace() << "EngineSync::notifyRateChanged" << pSyncable->getGroup() << bpm; } - updateMasterBpm(pSyncable, bpm); + updateLeaderBpm(pSyncable, bpm); } void EngineSync::requestBpmUpdate(Syncable* pSyncable, double bpm) { @@ -408,20 +410,20 @@ void EngineSync::requestBpmUpdate(Syncable* pSyncable, double bpm) { double mbaseBpm = 0.0; double mbpm = 0.0; double beatDistance = 0.0; - if (m_pMasterSyncable) { - mbaseBpm = m_pMasterSyncable->getBaseBpm(); - mbpm = m_pMasterSyncable->getBpm(); - beatDistance = m_pMasterSyncable->getBeatDistance(); + if (m_pLeaderSyncable) { + mbaseBpm = m_pLeaderSyncable->getBaseBpm(); + mbpm = m_pLeaderSyncable->getBpm(); + beatDistance = m_pLeaderSyncable->getBeatDistance(); } if (mbaseBpm != 0.0) { - // update from current master - pSyncable->updateMasterBeatDistance(beatDistance); - pSyncable->updateMasterBpm(mbpm); + // update from current leader + pSyncable->updateLeaderBeatDistance(beatDistance); + pSyncable->updateLeaderBpm(mbpm); } else { - // There is no master, adopt this bpm as master value - pSyncable->updateMasterBeatDistance(0.0); - pSyncable->updateMasterBpm(bpm); + // There is no leader, adopt this bpm as leader value + pSyncable->updateLeaderBeatDistance(0.0); + pSyncable->updateLeaderBpm(bpm); } } @@ -433,9 +435,9 @@ void EngineSync::notifyInstantaneousBpmChanged(Syncable* pSyncable, double bpm) return; } - // Do not update the master rate slider because instantaneous changes are + // Do not update the leader rate slider because instantaneous changes are // not user visible. - updateMasterInstantaneousBpm(pSyncable, bpm); + updateLeaderInstantaneousBpm(pSyncable, bpm); } void EngineSync::notifyBeatDistanceChanged(Syncable* pSyncable, double beatDistance) { @@ -447,15 +449,15 @@ void EngineSync::notifyBeatDistanceChanged(Syncable* pSyncable, double beatDista return; } - updateMasterBeatDistance(pSyncable, beatDistance); + updateLeaderBeatDistance(pSyncable, beatDistance); } Syncable* EngineSync::pickNonSyncSyncTarget(EngineChannel* pDontPick) const { - // First choice: the sync master, if it's a deck - if (m_pMasterSyncable && - m_pMasterSyncable->getChannel() && - m_pMasterSyncable->getChannel() != pDontPick) { - return m_pMasterSyncable; + // First choice: the sync leader, if it's a deck + if (m_pLeaderSyncable && + m_pLeaderSyncable->getChannel() && + m_pLeaderSyncable->getChannel() != pDontPick) { + return m_pLeaderSyncable; } Syncable* pFirstPlayingDeck = nullptr; @@ -467,13 +469,13 @@ Syncable* EngineSync::pickNonSyncSyncTarget(EngineChannel* pDontPick) const { continue; } - // Only consider channels that have a track loaded, are in the master + // Only consider channels that have a track loaded, are in the leader // mix, and are primary decks. if (pChannel->isActive() && pChannel->isMasterEnabled() && pChannel->isPrimaryDeck()) { EngineBuffer* pBuffer = pChannel->getEngineBuffer(); if (pBuffer && pBuffer->getBpm().isValid()) { if (pBuffer->getSpeed() != 0.0) { - if (pSyncable->getSyncMode() != SYNC_NONE) { + if (pSyncable->getSyncMode() != SyncMode::None) { // Second choice: first playing sync deck return pSyncable; } @@ -531,8 +533,8 @@ void EngineSync::onCallbackEnd(int sampleRate, int bufferSize) { m_pInternalClock->onCallbackEnd(sampleRate, bufferSize); } -EngineChannel* EngineSync::getMaster() const { - return m_pMasterSyncable ? m_pMasterSyncable->getChannel() : nullptr; +EngineChannel* EngineSync::getLeader() const { + return m_pLeaderSyncable ? m_pLeaderSyncable->getChannel() : nullptr; } Syncable* EngineSync::getSyncableForGroup(const QString& group) { @@ -553,42 +555,42 @@ bool EngineSync::syncDeckExists() const { return false; } -double EngineSync::masterBpm() const { - if (m_pMasterSyncable) { - return m_pMasterSyncable->getBpm(); +double EngineSync::leaderBpm() const { + if (m_pLeaderSyncable) { + return m_pLeaderSyncable->getBpm(); } return m_pInternalClock->getBpm(); } -double EngineSync::masterBeatDistance() const { - if (m_pMasterSyncable) { - return m_pMasterSyncable->getBeatDistance(); +double EngineSync::leaderBeatDistance() const { + if (m_pLeaderSyncable) { + return m_pLeaderSyncable->getBeatDistance(); } return m_pInternalClock->getBeatDistance(); } -double EngineSync::masterBaseBpm() const { - if (m_pMasterSyncable) { - return m_pMasterSyncable->getBaseBpm(); +double EngineSync::leaderBaseBpm() const { + if (m_pLeaderSyncable) { + return m_pLeaderSyncable->getBaseBpm(); } return m_pInternalClock->getBaseBpm(); } -void EngineSync::updateMasterBpm(Syncable* pSource, double bpm) { - //qDebug() << "EngineSync::updateMasterBpm" << pSource << bpm; +void EngineSync::updateLeaderBpm(Syncable* pSource, double bpm) { + //qDebug() << "EngineSync::updateLeaderBpm" << pSource << bpm; if (pSource != m_pInternalClock) { - m_pInternalClock->updateMasterBpm(bpm); + m_pInternalClock->updateLeaderBpm(bpm); } foreach (Syncable* pSyncable, m_syncables) { if (pSyncable == pSource || !pSyncable->isSynchronized()) { continue; } - pSyncable->updateMasterBpm(bpm); + pSyncable->updateLeaderBpm(bpm); } } -void EngineSync::updateMasterInstantaneousBpm(Syncable* pSource, double bpm) { +void EngineSync::updateLeaderInstantaneousBpm(Syncable* pSource, double bpm) { if (pSource != m_pInternalClock) { m_pInternalClock->updateInstantaneousBpm(bpm); } @@ -601,35 +603,35 @@ void EngineSync::updateMasterInstantaneousBpm(Syncable* pSource, double bpm) { } } -void EngineSync::updateMasterBeatDistance(Syncable* pSource, double beatDistance) { +void EngineSync::updateLeaderBeatDistance(Syncable* pSource, double beatDistance) { if (kLogger.traceEnabled()) { - kLogger.trace() << "EngineSync::setMasterBeatDistance" + kLogger.trace() << "EngineSync::updateLeaderBeatDistance" << (pSource ? pSource->getGroup() : "null") << beatDistance; } if (pSource != m_pInternalClock) { - m_pInternalClock->updateMasterBeatDistance(beatDistance); + m_pInternalClock->updateLeaderBeatDistance(beatDistance); } foreach (Syncable* pSyncable, m_syncables) { if (pSyncable == pSource || !pSyncable->isSynchronized()) { continue; } - pSyncable->updateMasterBeatDistance(beatDistance); + pSyncable->updateLeaderBeatDistance(beatDistance); } } -void EngineSync::reinitMasterParams(Syncable* pSource) { - // Important note! Because of the way sync works, the new master is usually not the same - // as the Syncable setting the master parameters (here, pSource). Notify the proper Syncable +void EngineSync::reinitLeaderParams(Syncable* pSource) { + // Important note! Because of the way sync works, the new leader is usually not the same + // as the Syncable setting the leader parameters (here, pSource). Notify the proper Syncable // so it can prepare itself. (This is a hack to undo half/double math so that we initialize // based on un-multiplied bpm values). - pSource->notifyMasterParamSource(); + pSource->notifyLeaderParamSource(); double beatDistance = pSource->getBeatDistance(); if (!pSource->isPlaying()) { // If the params source is not playing, but other syncables are, then we are a stopped - // explicit Master and we should not initialize the beat distance. Take it from the + // explicit Leader and we should not initialize the beat distance. Take it from the // internal clock instead, because that will be up to date with the playing deck(s). bool playingSyncables = false; for (Syncable* pSyncable : qAsConst(m_syncables)) { @@ -654,17 +656,17 @@ void EngineSync::reinitMasterParams(Syncable* pSource) { bpm = baseBpm; } if (kLogger.traceEnabled()) { - kLogger.trace() << "BaseSyncableListener::reinitMasterParams, source is" + kLogger.trace() << "BaseSyncableListener::reinitLeaderParams, source is" << pSource->getGroup() << beatDistance << baseBpm << bpm; } if (pSource != m_pInternalClock) { - m_pInternalClock->reinitMasterParams(beatDistance, baseBpm, bpm); + m_pInternalClock->reinitLeaderParams(beatDistance, baseBpm, bpm); } foreach (Syncable* pSyncable, m_syncables) { if (!pSyncable->isSynchronized()) { continue; } - pSyncable->reinitMasterParams(beatDistance, baseBpm, bpm); + pSyncable->reinitLeaderParams(beatDistance, baseBpm, bpm); } } diff --git a/src/engine/sync/enginesync.h b/src/engine/sync/enginesync.h index 0e3118010b2..22018ae7727 100644 --- a/src/engine/sync/enginesync.h +++ b/src/engine/sync/enginesync.h @@ -40,10 +40,10 @@ class EngineSync : public SyncableListener { void notifyPlayingAudible(Syncable* pSyncable, bool playingAudible) override; void notifyScratching(Syncable* pSyncable, bool scratching) override; - /// Used to pick a sync target for cases where master sync mode is not sufficient. + /// Used to pick a sync target for cases where Leader sync mode is not sufficient. /// Guaranteed to pick a Syncable that is a real deck and has an EngineBuffer, /// but can return nullptr if there are no choices. - /// First choice is master sync, if it's a real deck, + /// First choice is Leader sync, if it's a real deck, /// then it will fall back to the first playing syncable deck, /// then it will fall back to the first playing deck, /// then it will fall back to the first non-playing deck. @@ -56,83 +56,83 @@ class EngineSync : public SyncableListener { bool otherSyncedPlaying(const QString& group); void addSyncableDeck(Syncable* pSyncable); - EngineChannel* getMaster() const; + EngineChannel* getLeader() const; void onCallbackStart(int sampleRate, int bufferSize); void onCallbackEnd(int sampleRate, int bufferSize); private: - /// Iterate over decks, and based on sync and play status, pick a new master. + /// Iterate over decks, and based on sync and play status, pick a new Leader. /// if enabling_syncable is not null, we treat it as if it were enabled because we may /// be in the process of enabling it. - Syncable* pickMaster(Syncable* enabling_syncable); + Syncable* pickLeader(Syncable* enabling_syncable); - /// Find a deck to match against, used in the case where there is no sync master. + /// Find a deck to match against, used in the case where there is no sync Leader. /// Looks first for a playing deck, and falls back to the first non-playing deck. /// If the requester is playing, don't match against a non-playing deck because /// that would be strange behavior for the user. /// Returns nullptr if none can be found. Syncable* findBpmMatchTarget(Syncable* requester); - /// Activate a specific syncable as master. - void activateMaster(Syncable* pSyncable, bool explicitMaster); + /// Activate a specific syncable as Leader. + void activateLeader(Syncable* pSyncable, bool explicitLeader); /// Activate a specific channel as Follower. Sets the syncable's bpm and - /// beatDistance to match the master. + /// beatDistance to match the Leader. void activateFollower(Syncable* pSyncable); - // Activate a specific syncable as master, with the appropriate submode. - void activateMaster(Syncable* pSyncable, SyncMode masterType); + // Activate a specific syncable as Leader, with the appropriate submode. + void activateLeader(Syncable* pSyncable, SyncMode leaderType); /// Unsets all sync state on a Syncable. void deactivateSync(Syncable* pSyncable); - /// This utility method returns true if it finds a deck not in SYNC_NONE mode. + /// This utility method returns true if it finds a deck not in SyncMode::None. bool syncDeckExists() const; - /// Return the current BPM of the master Syncable. If no master syncable is + /// Return the current BPM of the Leader Syncable. If no Leader syncable is /// set then returns the BPM of the internal clock. - double masterBpm() const; + double leaderBpm() const; - /// Returns the current beat distance of the master Syncable. If no master + /// Returns the current beat distance of the Leader Syncable. If no Leader /// Syncable is set, then returns the beat distance of the internal clock. - double masterBeatDistance() const; + double leaderBeatDistance() const; - /// Returns the overall average BPM of the master Syncable if it were playing + /// Returns the overall average BPM of the Leader Syncable if it were playing /// at 1.0 rate. This is used to calculate half/double multipliers and whether - /// the master has a bpm at all. - double masterBaseBpm() const; + /// the Leader has a bpm at all. + double leaderBaseBpm() const; /// Set the BPM on every sync-enabled Syncable except pSource. - void updateMasterBpm(Syncable* pSource, double bpm); + void updateLeaderBpm(Syncable* pSource, double bpm); - /// Set the master instantaneous BPM on every sync-enabled Syncable except + /// Set the Leader instantaneous BPM on every sync-enabled Syncable except /// pSource. - void updateMasterInstantaneousBpm(Syncable* pSource, double bpm); + void updateLeaderInstantaneousBpm(Syncable* pSource, double bpm); - /// Set the master beat distance on every sync-enabled Syncable except + /// Set the Leader beat distance on every sync-enabled Syncable except /// pSource. - void updateMasterBeatDistance(Syncable* pSource, double beatDistance); + void updateLeaderBeatDistance(Syncable* pSource, double beatDistance); - /// Initialize the master parameters using the provided syncable as the source. + /// Initialize the leader parameters using the provided syncable as the source. /// This should only be called for "major" updates, like a new track or change in - /// master. Should not be called on every buffer callback. - void reinitMasterParams(Syncable* pSource); + /// leader. Should not be called on every buffer callback. + void reinitLeaderParams(Syncable* pSource); /// Iff there is a single playing syncable in sync mode, return it. - /// This is used to initialize master params. + /// This is used to initialize leader params. Syncable* getUniquePlayingSyncedDeck() const; /// Only for testing. Do not use. Syncable* getSyncableForGroup(const QString& group); /// Only for testing. Do not use. - Syncable* getMasterSyncable() override { - return m_pMasterSyncable; + Syncable* getLeaderSyncable() override { + return m_pLeaderSyncable; } - bool isSyncMaster(Syncable* pSyncable) { - if (isMaster(pSyncable->getSyncMode())) { - DEBUG_ASSERT(m_pMasterSyncable == pSyncable); + bool isSyncLeader(Syncable* pSyncable) { + if (isLeader(pSyncable->getSyncMode())) { + DEBUG_ASSERT(m_pLeaderSyncable == pSyncable); return true; } return false; @@ -143,14 +143,14 @@ class EngineSync : public SyncableListener { // If this code makes it to release we will all be very sad. enum SyncLockAlgorithm { // New behavior, which should work if beatgrids are reliable. - PREFER_IMPLICIT_MASTER, + PREFER_IMPLICIT_LEADER, // Old 2.3 behavior, which works around some issues with bad beatgrid detection, mostly // for auto DJ mode. PREFER_LOCK_BPM }; - FRIEND_TEST(EngineSyncTest, EnableOneDeckInitsMaster); - FRIEND_TEST(EngineSyncTest, EnableOneDeckInitializesMaster); + FRIEND_TEST(EngineSyncTest, EnableOneDeckInitsLeader); + FRIEND_TEST(EngineSyncTest, EnableOneDeckInitializesLeader); FRIEND_TEST(EngineSyncTest, SyncToNonSyncDeck); FRIEND_TEST(EngineSyncTest, SetFileBpmUpdatesLocalBpm); FRIEND_TEST(EngineSyncTest, BpmAdjustFactor); @@ -161,7 +161,7 @@ class EngineSync : public SyncableListener { /// The InternalClock syncable. InternalClock* m_pInternalClock; /// The current Syncable that is the leader. - Syncable* m_pMasterSyncable; + Syncable* m_pLeaderSyncable; /// The list of all Syncables registered via addSyncableDeck. QList m_syncables; }; diff --git a/src/engine/sync/internalclock.cpp b/src/engine/sync/internalclock.cpp index 4beec9733fb..a2d37f1adcd 100644 --- a/src/engine/sync/internalclock.cpp +++ b/src/engine/sync/internalclock.cpp @@ -17,14 +17,14 @@ const mixxx::Logger kLogger("InternalClock"); InternalClock::InternalClock(const QString& group, SyncableListener* pEngineSync) : m_group(group), m_pEngineSync(pEngineSync), - m_mode(SYNC_NONE), + m_mode(SyncMode::None), m_iOldSampleRate(44100), m_dOldBpm(124.0), m_dBaseBpm(124.0), m_dBeatLength(m_iOldSampleRate * 60.0 / m_dOldBpm), m_dClockPosition(0) { // Pick a wide range (1 to 200) and allow out of bounds sets. This lets you - // map a soft-takeover MIDI knob to the master BPM. This also creates bpm_up + // map a soft-takeover MIDI knob to the leader BPM. This also creates bpm_up // and bpm_down controls. // bpm_up / bpm_down steps by 1 // bpm_up_small / bpm_down_small steps by 0.1 @@ -42,12 +42,14 @@ InternalClock::InternalClock(const QString& group, SyncableListener* pEngineSync this, &InternalClock::slotBeatDistanceChanged, Qt::DirectConnection); - m_pSyncMasterEnabled.reset( - new ControlPushButton(ConfigKey(m_group, "sync_master"))); - m_pSyncMasterEnabled->setButtonMode(ControlPushButton::TOGGLE); - m_pSyncMasterEnabled->setStates(3); - m_pSyncMasterEnabled->connectValueChangeRequest( - this, &InternalClock::slotSyncMasterEnabledChangeRequest, Qt::DirectConnection); + m_pSyncLeaderEnabled.reset( + new ControlPushButton(ConfigKey(m_group, "sync_leader"))); + m_pSyncLeaderEnabled->setButtonMode(ControlPushButton::TOGGLE); + m_pSyncLeaderEnabled->setStates(3); + m_pSyncLeaderEnabled->connectValueChangeRequest( + this, &InternalClock::slotSyncLeaderEnabledChangeRequest, Qt::DirectConnection); + ControlDoublePrivate::insertAlias(ConfigKey(m_group, "sync_master"), + ConfigKey(m_group, "sync_leader")); } InternalClock::~InternalClock() { @@ -57,7 +59,7 @@ void InternalClock::setSyncMode(SyncMode mode) { // Syncable has absolutely no say in the matter. This is what EngineSync // requires. Bypass confirmation by using setAndConfirm. m_mode = mode; - m_pSyncMasterEnabled->setAndConfirm(SyncModeToMasterLight(mode)); + m_pSyncLeaderEnabled->setAndConfirm(static_cast(SyncModeToLeaderLight(mode))); } void InternalClock::notifyUniquePlaying() { @@ -68,30 +70,30 @@ void InternalClock::requestSync() { // TODO(owilliams): This should probably be how we reset the internal beat distance. } -void InternalClock::slotSyncMasterEnabledChangeRequest(double state) { +void InternalClock::slotSyncLeaderEnabledChangeRequest(double state) { SyncMode mode = m_mode; //Note: internal clock is always sync enabled if (state > 0.0) { - if (mode == SYNC_MASTER_EXPLICIT) { - // Already master. + if (mode == SyncMode::LeaderExplicit) { + // Already leader. return; } - if (mode == SYNC_MASTER_SOFT) { - // user request: make master explicit - m_mode = SYNC_MASTER_EXPLICIT; + if (mode == SyncMode::LeaderSoft) { + // user request: make leader explicit + m_mode = SyncMode::LeaderExplicit; return; } - if (mode == SYNC_NONE) { + if (mode == SyncMode::None) { m_dBaseBpm = m_dOldBpm; } - m_pEngineSync->requestSyncMode(this, SYNC_MASTER_EXPLICIT); + m_pEngineSync->requestSyncMode(this, SyncMode::LeaderExplicit); } else { - // Turning off master goes back to follower mode. - if (mode == SYNC_FOLLOWER) { - // Already not master. + // Turning off leader goes back to follower mode. + if (mode == SyncMode::Follower) { + // Already not leader. return; } - m_pEngineSync->requestSyncMode(this, SYNC_FOLLOWER); + m_pEngineSync->requestSyncMode(this, SyncMode::Follower); } } @@ -103,9 +105,9 @@ double InternalClock::getBeatDistance() const { return m_dClockPosition / m_dBeatLength; } -void InternalClock::updateMasterBeatDistance(double beatDistance) { +void InternalClock::updateLeaderBeatDistance(double beatDistance) { if (kLogger.traceEnabled()) { - kLogger.trace() << "InternalClock::setMasterBeatDistance" << beatDistance; + kLogger.trace() << "InternalClock::updateLeaderBeatDistance" << beatDistance; } m_dClockPosition = beatDistance * m_dBeatLength; m_pClockBeatDistance->set(beatDistance); @@ -121,7 +123,7 @@ double InternalClock::getBpm() const { return m_pClockBpm->get(); } -void InternalClock::updateMasterBpm(double bpm) { +void InternalClock::updateLeaderBpm(double bpm) { if (kLogger.traceEnabled()) { kLogger.trace() << "InternalClock::setBpm" << bpm; } @@ -140,19 +142,19 @@ void InternalClock::updateInstantaneousBpm(double bpm) { Q_UNUSED(bpm); } -void InternalClock::notifyMasterParamSource() { +void InternalClock::notifyLeaderParamSource() { } -void InternalClock::reinitMasterParams(double beatDistance, double baseBpm, double bpm) { +void InternalClock::reinitLeaderParams(double beatDistance, double baseBpm, double bpm) { if (kLogger.traceEnabled()) { - kLogger.trace() << "InternalClock::reinitMasterParams" << beatDistance << baseBpm << bpm; + kLogger.trace() << "InternalClock::reinitLeaderParams" << beatDistance << baseBpm << bpm; } if (bpm <= 0.0 || baseBpm <= 0.0) { return; } m_dBaseBpm = baseBpm; - updateMasterBpm(bpm); - updateMasterBeatDistance(beatDistance); + updateLeaderBpm(bpm); + updateLeaderBeatDistance(beatDistance); } void InternalClock::slotBaseBpmChanged(double baseBpm) { @@ -168,7 +170,7 @@ void InternalClock::slotBeatDistanceChanged(double beatDistance) { if (beatDistance < 0.0 || beatDistance > 1.0) { return; } - updateMasterBeatDistance(beatDistance); + updateLeaderBeatDistance(beatDistance); } void InternalClock::updateBeatLength(int sampleRate, double bpm) { @@ -189,7 +191,7 @@ void InternalClock::updateBeatLength(int sampleRate, double bpm) { // that last term is 1 over bpm. if (qFuzzyCompare(bpm, 0)) { - qDebug() << "WARNING: Master bpm reported to be zero, internal clock guessing 124bpm"; + qDebug() << "WARNING: Leader bpm reported to be zero, internal clock guessing 124bpm"; m_dBeatLength = (sampleRate * 60.0) / 124.0; m_dOldBpm = 124.0; } else { @@ -204,7 +206,7 @@ void InternalClock::updateBeatLength(int sampleRate, double bpm) { m_iOldSampleRate = sampleRate; // Restore the old beat distance. - updateMasterBeatDistance(oldBeatDistance); + updateLeaderBeatDistance(oldBeatDistance); } void InternalClock::onCallbackStart(int sampleRate, int bufferSize) { diff --git a/src/engine/sync/internalclock.h b/src/engine/sync/internalclock.h index d27e3939fd0..d8253899d36 100644 --- a/src/engine/sync/internalclock.h +++ b/src/engine/sync/internalclock.h @@ -13,11 +13,11 @@ class ControlPushButton; class EngineSync; class EngineChannel; -/// Internal Clock is a Master Sync object that provides a source of constant +/// Internal Clock is a Sync Lock object that provides a source of constant /// tempo when needed. The EngineSync will decide when to make the Internal -/// Clock master. The Internal Clock should not be given any new sources of +/// Clock leader. The Internal Clock should not be given any new sources of /// bpm clock. If someone wants to write a Midi Clock source, it should be -/// a separate Syncable object that can become master. +/// a separate Syncable object that can become ledaer. class InternalClock : public QObject, public Clock, public Syncable { Q_OBJECT public: @@ -48,14 +48,14 @@ class InternalClock : public QObject, public Clock, public Syncable { } double getBeatDistance() const override; - void updateMasterBeatDistance(double beatDistance) override; + void updateLeaderBeatDistance(double beatDistance) override; double getBaseBpm() const override; - void updateMasterBpm(double bpm) override; - void notifyMasterParamSource() override; + void updateLeaderBpm(double bpm) override; + void notifyLeaderParamSource() override; double getBpm() const override; void updateInstantaneousBpm(double bpm) override; - void reinitMasterParams(double beatDistance, double baseBpm, double bpm) override; + void reinitLeaderParams(double beatDistance, double baseBpm, double bpm) override; void onCallbackStart(int sampleRate, int bufferSize); void onCallbackEnd(int sampleRate, int bufferSize); @@ -63,7 +63,7 @@ class InternalClock : public QObject, public Clock, public Syncable { private slots: void slotBaseBpmChanged(double baseBpm); void slotBeatDistanceChanged(double beatDistance); - void slotSyncMasterEnabledChangeRequest(double state); + void slotSyncLeaderEnabledChangeRequest(double state); private: void updateBeatLength(int sampleRate, double bpm); @@ -72,7 +72,7 @@ class InternalClock : public QObject, public Clock, public Syncable { SyncableListener* m_pEngineSync; QScopedPointer m_pClockBpm; QScopedPointer m_pClockBeatDistance; - QScopedPointer m_pSyncMasterEnabled; + QScopedPointer m_pSyncLeaderEnabled; SyncMode m_mode; int m_iOldSampleRate; diff --git a/src/engine/sync/syncable.h b/src/engine/sync/syncable.h index f96b0153690..65d43d3135d 100644 --- a/src/engine/sync/syncable.h +++ b/src/engine/sync/syncable.h @@ -1,70 +1,88 @@ #pragma once +#include #include class EngineChannel; -enum SyncMode { - SYNC_INVALID = -1, - SYNC_NONE = 0, - SYNC_FOLLOWER = 1, - // SYNC_MASTER_SOFT is a master that Mixxx has chosen automatically. - // depending on how decks stop and start, it may reassign soft master at will. - SYNC_MASTER_SOFT = 2, - // SYNC_MASTER_EXPLICIT represents an explicit request that the synacable be - // master. Mixxx will only remove a SYNC_MASTER_SOFT if the track is stopped or +enum class SyncMode { + Invalid = -1, + None = 0, + Follower = 1, + // LeaderSoft is a leader that Mixxx has chosen automatically. + // depending on how decks stop and start, it may reassign soft leader at will. + LeaderSoft = 2, + // LeaderExplicit represents an explicit request that the syncable be + // leader. Mixxx will only remove a LeaderSoft if the track is stopped or // ejected. - SYNC_MASTER_EXPLICIT = 3, - SYNC_NUM_MODES + LeaderExplicit = 3, + NumModes }; +inline QDebug operator<<(QDebug debug, const SyncMode& mode) { + switch (mode) { + case SyncMode::Invalid: + return debug << "SyncMode::Invalid"; + case SyncMode::None: + return debug << "SyncMode::None"; + case SyncMode::Follower: + return debug << "SyncMode::Follower"; + case SyncMode::LeaderSoft: + return debug << "SyncMode::LeaderSoft"; + case SyncMode::LeaderExplicit: + return debug << "SyncMode::LeaderExplicit"; + case SyncMode::NumModes: + return debug << "SyncMode::NumModes"; + } + return debug << "SyncMode::Invalid (not in switch/case)"; +} inline SyncMode syncModeFromDouble(double value) { // msvs does not allow to cast from double to an enum SyncMode mode = static_cast(int(value)); - if (mode >= SYNC_NUM_MODES || mode < 0) { - return SYNC_NONE; + if (mode >= SyncMode::NumModes || mode == SyncMode::Invalid) { + return SyncMode::None; } return mode; } inline bool toSynchronized(SyncMode mode) { - return mode > SYNC_NONE; + return mode > SyncMode::None; } inline bool isFollower(SyncMode mode) { - return (mode == SYNC_FOLLOWER); + return (mode == SyncMode::Follower); } -inline bool isMaster(SyncMode mode) { - return (mode == SYNC_MASTER_SOFT || mode == SYNC_MASTER_EXPLICIT); +inline bool isLeader(SyncMode mode) { + return (mode == SyncMode::LeaderSoft || mode == SyncMode::LeaderExplicit); } -enum SyncMasterLight { - MASTER_INVALID = -1, - MASTER_OFF = 0, - MASTER_SOFT = 1, - MASTER_EXPLICIT = 2, +enum class SyncLeaderLight { + Invalid = -1, + Off = 0, + Soft = 1, + Explicit = 2, }; -inline SyncMasterLight SyncModeToMasterLight(SyncMode mode) { +inline SyncLeaderLight SyncModeToLeaderLight(SyncMode mode) { switch (mode) { - case SYNC_INVALID: - case SYNC_NONE: - case SYNC_FOLLOWER: - return MASTER_OFF; - case SYNC_MASTER_SOFT: - return MASTER_SOFT; - case SYNC_MASTER_EXPLICIT: - return MASTER_EXPLICIT; + case SyncMode::Invalid: + case SyncMode::None: + case SyncMode::Follower: + return SyncLeaderLight::Off; + case SyncMode::LeaderSoft: + return SyncLeaderLight::Soft; + case SyncMode::LeaderExplicit: + return SyncLeaderLight::Explicit; break; - case SYNC_NUM_MODES: + case SyncMode::NumModes: break; } - return MASTER_INVALID; + return SyncLeaderLight::Invalid; } /// Syncable is an abstract base class for any object that wants to participate -/// in Master Sync. +/// in Sync Lock. class Syncable { public: virtual ~Syncable() = default; @@ -103,27 +121,27 @@ class Syncable { virtual double getBaseBpm() const = 0; // The following functions are used to tell syncables about the state of the - // current Sync Master. + // current Sync Leader. // Must never result in a call to // SyncableListener::notifyBeatDistanceChanged or signal loops could occur. - virtual void updateMasterBeatDistance(double beatDistance) = 0; + virtual void updateLeaderBeatDistance(double beatDistance) = 0; // Update the current playback speed (not including scratch values) - // of the current master. + // of the current leader. // Must never result in a call to SyncableListener::notifyBpmChanged or // signal loops could occur. - virtual void updateMasterBpm(double bpm) = 0; + virtual void updateLeaderBpm(double bpm) = 0; - // Tells a Syncable that it's going to be used as a source for master + // Tells a Syncable that it's going to be used as a source for leader // params. This is a gross hack so that the SyncControl can undo its // half/double adjustment so bpms are initialized correctly. - virtual void notifyMasterParamSource() = 0; + virtual void notifyLeaderParamSource() = 0; - // Perform a reset of Master parameters. This function also triggers recalculation + // Perform a reset of Leader parameters. This function also triggers recalculation // of half-double multiplier. - virtual void reinitMasterParams(double beatDistance, double baseBpm, double bpm) = 0; + virtual void reinitLeaderParams(double beatDistance, double baseBpm, double bpm) = 0; - // Update the playback speed of the master, including scratch values. + // Update the playback speed of the leader, including scratch values. // Must never result in a call to // SyncableListener::notifyInstantaneousBpmChanged or signal loops could // occur. @@ -141,7 +159,7 @@ class SyncableListener { // Syncable::notifySyncModeChanged. virtual void requestSyncMode(Syncable* pSyncable, SyncMode mode) = 0; - // A Syncable must never call notifyBpmChanged in response to a setMasterBpm() + // A Syncable must never call notifyBpmChanged in response to a updateLeaderBpm() // call. virtual void notifyBaseBpmChanged(Syncable* pSyncable, double bpm) = 0; virtual void notifyRateChanged(Syncable* pSyncable, double bpm) = 0; @@ -162,5 +180,5 @@ class SyncableListener { virtual void notifyPlayingAudible(Syncable* pSyncable, bool playingAudible) = 0; - virtual Syncable* getMasterSyncable() = 0; + virtual Syncable* getLeaderSyncable() = 0; }; diff --git a/src/engine/sync/synccontrol.cpp b/src/engine/sync/synccontrol.cpp index 5762a03dd79..9b863b4cb6c 100644 --- a/src/engine/sync/synccontrol.cpp +++ b/src/engine/sync/synccontrol.cpp @@ -33,14 +33,14 @@ SyncControl::SyncControl(const QString& group, m_pBpmControl(nullptr), m_pRateControl(nullptr), m_bOldScratching(false), - m_masterBpmAdjustFactor(kBpmUnity), + m_leaderBpmAdjustFactor(kBpmUnity), m_unmultipliedTargetBeatDistance(0.0), m_pBpm(nullptr), m_pLocalBpm(nullptr), m_pRateRatio(nullptr), m_pVCEnabled(nullptr), m_pSyncPhaseButton(nullptr) { - // Play button. We only listen to this to disable master if the deck is + // Play button. We only listen to this to disable leader if the deck is // stopped. m_pPlayButton = new ControlProxy(group, "play", this); m_pPlayButton->connectValueChanged(this, &SyncControl::slotControlPlay, @@ -48,16 +48,18 @@ SyncControl::SyncControl(const QString& group, m_pSyncMode.reset(new ControlPushButton(ConfigKey(group, "sync_mode"))); m_pSyncMode->setButtonMode(ControlPushButton::TOGGLE); - m_pSyncMode->setStates(SYNC_NUM_MODES); + m_pSyncMode->setStates(static_cast(SyncMode::NumModes)); m_pSyncMode->connectValueChangeRequest( this, &SyncControl::slotSyncModeChangeRequest, Qt::DirectConnection); - m_pSyncMasterEnabled.reset( - new ControlPushButton(ConfigKey(group, "sync_master"))); - m_pSyncMasterEnabled->setButtonMode(ControlPushButton::TOGGLE); - m_pSyncMasterEnabled->setStates(3); - m_pSyncMasterEnabled->connectValueChangeRequest( - this, &SyncControl::slotSyncMasterEnabledChangeRequest, Qt::DirectConnection); + m_pSyncLeaderEnabled.reset( + new ControlPushButton(ConfigKey(group, "sync_leader"))); + m_pSyncLeaderEnabled->setButtonMode(ControlPushButton::TOGGLE); + m_pSyncLeaderEnabled->setStates(3); + m_pSyncLeaderEnabled->connectValueChangeRequest( + this, &SyncControl::slotSyncLeaderEnabledChangeRequest, Qt::DirectConnection); + ControlDoublePrivate::insertAlias(ConfigKey(group, "sync_master"), + ConfigKey(group, "sync_leader")); m_pSyncEnabled.reset( new ControlPushButton(ConfigKey(group, "sync_enabled"))); @@ -125,16 +127,16 @@ void SyncControl::setSyncMode(SyncMode mode) { } // SyncControl has absolutely no say in the matter. This is what EngineSync // requires. Bypass confirmation by using setAndConfirm. - m_pSyncMode->setAndConfirm(mode); - m_pSyncEnabled->setAndConfirm(mode != SYNC_NONE); - m_pSyncMasterEnabled->setAndConfirm(SyncModeToMasterLight(mode)); - if (mode == SYNC_FOLLOWER) { + m_pSyncMode->setAndConfirm(static_cast(mode)); + m_pSyncEnabled->setAndConfirm(mode != SyncMode::None); + m_pSyncLeaderEnabled->setAndConfirm(static_cast(SyncModeToLeaderLight(mode))); + if (mode == SyncMode::Follower) { if (m_pVCEnabled && m_pVCEnabled->toBool()) { // If follower mode is enabled, disable vinyl control. m_pVCEnabled->set(0.0); } } - if (mode != SYNC_NONE && m_pPassthroughEnabled->toBool()) { + if (mode != SyncMode::None && m_pPassthroughEnabled->toBool()) { // If any sync mode is enabled and passthrough was on somehow, disable passthrough. // This is very unlikely to happen so this deserves a warning. qWarning() << "Notified of sync mode change when passthrough was " @@ -142,8 +144,8 @@ void SyncControl::setSyncMode(SyncMode mode) { "must disable passthrough"; m_pPassthroughEnabled->set(0.0); } - if (mode == SYNC_NONE) { - m_masterBpmAdjustFactor = kBpmUnity; + if (mode == SyncMode::None) { + m_leaderBpmAdjustFactor = kBpmUnity; } } @@ -177,18 +179,18 @@ bool SyncControl::isAudible() const { double SyncControl::adjustSyncBeatDistance(double beatDistance) const { // Similar to adjusting the target beat distance, when we report our beat - // distance we need to adjust it by the master bpm adjustment factor. If - // we've been doubling the master bpm, we need to divide it in half. If - // we've been halving the master bpm, we need to double it. Both operations + // distance we need to adjust it by the leader bpm adjustment factor. If + // we've been doubling the leader bpm, we need to divide it in half. If + // we've been halving the leader bpm, we need to double it. Both operations // also need to account for if the longer beat is past its halfway point. // // This is the inverse of the updateTargetBeatDistance function below. - if (m_masterBpmAdjustFactor == kBpmDouble) { + if (m_leaderBpmAdjustFactor == kBpmDouble) { beatDistance /= kBpmDouble; if (m_unmultipliedTargetBeatDistance >= 0.5) { beatDistance += 0.5; } - } else if (m_masterBpmAdjustFactor == kBpmHalve) { + } else if (m_leaderBpmAdjustFactor == kBpmHalve) { if (beatDistance >= 0.5) { beatDistance -= 0.5; } @@ -203,12 +205,12 @@ double SyncControl::getBeatDistance() const { } double SyncControl::getBaseBpm() const { - return m_pLocalBpm->get() / m_masterBpmAdjustFactor; + return m_pLocalBpm->get() / m_leaderBpmAdjustFactor; } -void SyncControl::updateMasterBeatDistance(double beatDistance) { +void SyncControl::updateLeaderBeatDistance(double beatDistance) { if (kLogger.traceEnabled()) { - kLogger.trace() << getGroup() << "SyncControl::setMasterBeatDistance" + kLogger.trace() << getGroup() << "SyncControl::updateLeaderBeatDistance" << beatDistance; } // Set the BpmControl target beat distance to beatDistance, adjusted by @@ -219,13 +221,13 @@ void SyncControl::updateMasterBeatDistance(double beatDistance) { updateTargetBeatDistance(); } -void SyncControl::updateMasterBpm(double bpm) { +void SyncControl::updateLeaderBpm(double bpm) { if (kLogger.traceEnabled()) { - kLogger.trace() << getGroup() << "SyncControl::setMasterBpm" << bpm; + kLogger.trace() << getGroup() << "SyncControl::updateLeaderBpm" << bpm; } VERIFY_OR_DEBUG_ASSERT(isSynchronized()) { - qWarning() << "WARNING: Logic Error: setBpm called on SYNC_NONE syncable."; + qWarning() << "WARNING: Logic Error: setBpm called on SyncMode::None syncable."; return; } @@ -236,23 +238,23 @@ void SyncControl::updateMasterBpm(double bpm) { double localBpm = m_pLocalBpm->get(); if (localBpm > 0.0) { - m_pRateRatio->set(bpm * m_masterBpmAdjustFactor / localBpm); + m_pRateRatio->set(bpm * m_leaderBpmAdjustFactor / localBpm); } } -void SyncControl::notifyMasterParamSource() { - m_masterBpmAdjustFactor = kBpmUnity; +void SyncControl::notifyLeaderParamSource() { + m_leaderBpmAdjustFactor = kBpmUnity; } -void SyncControl::reinitMasterParams( +void SyncControl::reinitLeaderParams( double beatDistance, double baseBpm, double bpm) { if (kLogger.traceEnabled()) { - kLogger.trace() << "SyncControl::setMasterParams" << getGroup() + kLogger.trace() << "SyncControl::reinitLeaderParams" << getGroup() << beatDistance << baseBpm << bpm; } - m_masterBpmAdjustFactor = determineBpmMultiplier(fileBpm(), baseBpm); - updateMasterBpm(bpm); - updateMasterBeatDistance(beatDistance); + m_leaderBpmAdjustFactor = determineBpmMultiplier(fileBpm(), baseBpm); + updateLeaderBpm(bpm); + updateLeaderBeatDistance(beatDistance); } double SyncControl::determineBpmMultiplier(double myBpm, double targetBpm) const { @@ -277,7 +279,7 @@ void SyncControl::updateTargetBeatDistance() { kLogger.trace() << getGroup() << "SyncControl::updateTargetBeatDistance, unmult distance" - << targetDistance << m_masterBpmAdjustFactor; + << targetDistance << m_leaderBpmAdjustFactor; } // Determining the target distance is not as simple as x2 or /2. Since one @@ -285,12 +287,12 @@ void SyncControl::updateTargetBeatDistance() { // position of the longer beat is past its halfway point. e.g. 0.0 for the // long beat is 0.0 of the short beat, but 0.5 for the long beat is also // 0.0 for the short beat. - if (m_masterBpmAdjustFactor == kBpmDouble) { + if (m_leaderBpmAdjustFactor == kBpmDouble) { if (targetDistance >= 0.5) { targetDistance -= 0.5; } targetDistance *= kBpmDouble; - } else if (m_masterBpmAdjustFactor == kBpmHalve) { + } else if (m_leaderBpmAdjustFactor == kBpmHalve) { targetDistance *= kBpmHalve; // Our beat distance CO is still a buffer behind, so take the current value. if (m_pBpmControl->getBeatDistance(getSampleOfTrack().current) >= 0.5) { @@ -306,21 +308,21 @@ void SyncControl::updateTargetBeatDistance() { double SyncControl::getBpm() const { if (kLogger.traceEnabled()) { kLogger.trace() << getGroup() << "SyncControl::getBpm()" - << m_pBpm->get() << "/" << m_masterBpmAdjustFactor; + << m_pBpm->get() << "/" << m_leaderBpmAdjustFactor; } - return m_pBpm->get() / m_masterBpmAdjustFactor; + return m_pBpm->get() / m_leaderBpmAdjustFactor; } void SyncControl::updateInstantaneousBpm(double bpm) { // Adjust the incoming bpm by the multiplier. - m_pBpmControl->updateInstantaneousBpm(bpm * m_masterBpmAdjustFactor); + m_pBpmControl->updateInstantaneousBpm(bpm * m_leaderBpmAdjustFactor); } void SyncControl::reportTrackPosition(double fractionalPlaypos) { - // If we're close to the end, and master, disable master so we don't stop + // If we're close to the end, and leader, disable leader so we don't stop // the party. - if (isMaster(getSyncMode()) && fractionalPlaypos >= 1.0) { - m_pChannel->getEngineBuffer()->requestSyncMode(SYNC_FOLLOWER); + if (isLeader(getSyncMode()) && fractionalPlaypos >= 1.0) { + m_pChannel->getEngineBuffer()->requestSyncMode(SyncMode::Follower); } } @@ -346,23 +348,23 @@ void SyncControl::trackBeatsUpdated(mixxx::BeatsPointer pBeats) { } m_pBeats = pBeats; - m_masterBpmAdjustFactor = kBpmUnity; + m_leaderBpmAdjustFactor = kBpmUnity; SyncMode syncMode = getSyncMode(); - if (isMaster(syncMode)) { + if (isLeader(syncMode)) { if (!m_pBeats) { // If the track was ejected or suddenly has no beats, we can no longer - // be master. - m_pChannel->getEngineBuffer()->requestSyncMode(SYNC_FOLLOWER); + // be leader. + m_pChannel->getEngineBuffer()->requestSyncMode(SyncMode::Follower); } else { - // We are remaining master, so notify the engine with our update. + // We are remaining leader, so notify the engine with our update. m_pBpmControl->updateLocalBpm(); m_pEngineSync->notifyBaseBpmChanged(this, getBaseBpm()); } } else if (isFollower(syncMode)) { // If we were a follower, requesting sync mode refreshes - // the soft master -- if we went from having no bpm to having - // a bpm, we might need to become master. + // the soft leader -- if we went from having no bpm to having + // a bpm, we might need to become leader. m_pChannel->getEngineBuffer()->requestSyncMode(syncMode); m_pBpmControl->updateLocalBpm(); } @@ -376,16 +378,16 @@ void SyncControl::slotControlPlay(double play) { } void SyncControl::slotVinylControlChanged(double enabled) { - if (enabled != 0 && getSyncMode() == SYNC_FOLLOWER) { + if (enabled != 0 && getSyncMode() == SyncMode::Follower) { // If vinyl control was enabled and we're a follower, disable sync mode. - m_pChannel->getEngineBuffer()->requestSyncMode(SYNC_NONE); + m_pChannel->getEngineBuffer()->requestSyncMode(SyncMode::None); } } void SyncControl::slotPassthroughChanged(double enabled) { if (enabled != 0 && isSynchronized()) { // If passthrough was enabled and sync was on, disable it. - m_pChannel->getEngineBuffer()->requestSyncMode(SYNC_NONE); + m_pChannel->getEngineBuffer()->requestSyncMode(SyncMode::None); } } @@ -394,16 +396,16 @@ void SyncControl::slotSyncModeChangeRequest(double state) { kLogger.trace() << getGroup() << "SyncControl::slotSyncModeChangeRequest"; } SyncMode mode = syncModeFromDouble(state); - if (m_pPassthroughEnabled->toBool() && mode != SYNC_NONE) { + if (m_pPassthroughEnabled->toBool() && mode != SyncMode::None) { qDebug() << "Disallowing enabling of sync mode when passthrough active"; } else { m_pChannel->getEngineBuffer()->requestSyncMode(mode); } } -void SyncControl::slotSyncMasterEnabledChangeRequest(double state) { +void SyncControl::slotSyncLeaderEnabledChangeRequest(double state) { if (kLogger.traceEnabled()) { - kLogger.trace() << "SyncControl::slotSyncMasterEnabledChangeRequest" << getGroup(); + kLogger.trace() << "SyncControl::slotSyncLeaderEnabledChangeRequest" << getGroup(); } SyncMode mode = getSyncMode(); if (state > 0.0) { @@ -411,15 +413,15 @@ void SyncControl::slotSyncMasterEnabledChangeRequest(double state) { qDebug() << "Disallowing enabling of sync mode when passthrough active"; return; } - m_pChannel->getEngineBuffer()->requestSyncMode(SYNC_MASTER_EXPLICIT); + m_pChannel->getEngineBuffer()->requestSyncMode(SyncMode::LeaderExplicit); } else { - // Turning off master goes back to follower mode. + // Turning off leader goes back to follower mode. switch (mode) { - case SYNC_MASTER_EXPLICIT: - m_pChannel->getEngineBuffer()->requestSyncMode(SYNC_MASTER_SOFT); + case SyncMode::LeaderExplicit: + m_pChannel->getEngineBuffer()->requestSyncMode(SyncMode::LeaderSoft); break; - case SYNC_MASTER_SOFT: - m_pChannel->getEngineBuffer()->requestSyncMode(SYNC_FOLLOWER); + case SyncMode::LeaderSoft: + m_pChannel->getEngineBuffer()->requestSyncMode(SyncMode::Follower); break; default: return; @@ -449,23 +451,23 @@ void SyncControl::setLocalBpm(double local_bpm) { m_prevLocalBpm.setValue(local_bpm); SyncMode syncMode = getSyncMode(); - if (syncMode <= SYNC_NONE) { + if (syncMode <= SyncMode::None) { return; } double bpm = local_bpm * m_pRateRatio->get(); if (isFollower(syncMode)) { - // In this case we need an update from the current master to adjust - // the rate that we continue with the master BPM. If there is no - // master bpm, our bpm value is adopted and the m_masterBpmAdjustFactor + // In this case we need an update from the current leader to adjust + // the rate that we continue with the leader BPM. If there is no + // leader bpm, our bpm value is adopted and the m_leaderBpmAdjustFactor // is reset to 1; m_pEngineSync->requestBpmUpdate(this, bpm); } else { - DEBUG_ASSERT(isMaster(syncMode)); - // We might have adopted an adjust factor when becoming master. + DEBUG_ASSERT(isLeader(syncMode)); + // We might have adopted an adjust factor when becoming leader. // Keep it when reporting our bpm. - m_pEngineSync->notifyBaseBpmChanged(this, bpm / m_masterBpmAdjustFactor); + m_pEngineSync->notifyBaseBpmChanged(this, bpm / m_leaderBpmAdjustFactor); } } @@ -487,9 +489,9 @@ void SyncControl::slotRateChanged() { kLogger.trace() << getGroup() << "SyncControl::slotRateChanged" << m_pRateRatio->get() << bpm; } if (bpm > 0 && isSynchronized()) { - // When reporting our bpm, remove the multiplier so the masters all + // When reporting our bpm, remove the multiplier so the leaders all // think the followers have the same bpm. - m_pEngineSync->notifyRateChanged(this, bpm / m_masterBpmAdjustFactor); + m_pEngineSync->notifyRateChanged(this, bpm / m_leaderBpmAdjustFactor); } } @@ -500,9 +502,9 @@ void SyncControl::reportPlayerSpeed(double speed, bool scratching) { // No need to disable sync mode while scratching, the engine won't // get confused. } - // When reporting our speed, remove the multiplier so the masters all + // When reporting our speed, remove the multiplier so the leaders all // think the followers have the same bpm. - double instantaneous_bpm = m_pLocalBpm->get() * speed / m_masterBpmAdjustFactor; + double instantaneous_bpm = m_pLocalBpm->get() * speed / m_leaderBpmAdjustFactor; m_pEngineSync->notifyInstantaneousBpmChanged(this, instantaneous_bpm); } diff --git a/src/engine/sync/synccontrol.h b/src/engine/sync/synccontrol.h index 1654a0208b1..d0856f6c166 100644 --- a/src/engine/sync/synccontrol.h +++ b/src/engine/sync/synccontrol.h @@ -13,7 +13,7 @@ class ControlObject; class ControlProxy; class ControlPushButton; -/// SyncControl is the Master Sync object for playback decks. +/// SyncControl is the Sync Lock object for playback decks. class SyncControl : public EngineControl, public Syncable { Q_OBJECT public: @@ -47,12 +47,12 @@ class SyncControl : public EngineControl, public Syncable { // Must never result in a call to // SyncableListener::notifyBeatDistanceChanged or signal loops could occur. - void updateMasterBeatDistance(double beatDistance) override; + void updateLeaderBeatDistance(double beatDistance) override; // Must never result in a call to // SyncableListener::notifyBpmChanged or signal loops could occur. - void updateMasterBpm(double bpm) override; - void notifyMasterParamSource() override; - void reinitMasterParams(double beatDistance, double baseBpm, double bpm) override; + void updateLeaderBpm(double bpm) override; + void notifyLeaderParamSource() override; + void reinitLeaderParams(double beatDistance, double baseBpm, double bpm) override; // Must never result in a call to // SyncableListener::notifyInstantaneousBpmChanged or signal loops could @@ -83,13 +83,13 @@ class SyncControl : public EngineControl, public Syncable { // Change request handlers for sync properties. void slotSyncModeChangeRequest(double state); void slotSyncEnabledChangeRequest(double enabled); - void slotSyncMasterEnabledChangeRequest(double state); + void slotSyncLeaderEnabledChangeRequest(double state); private: FRIEND_TEST(SyncControlTest, TestDetermineBpmMultiplier); // Sometimes it's best to match bpms based on half or double the target // bpm. e.g. 70 matches better with 140/2. This function returns the - // best factor for multiplying the master bpm to get a bpm this syncable + // best factor for multiplying the leader bpm to get a bpm this syncable // should match against. double determineBpmMultiplier(double myBpm, double targetBpm) const; double fileBpm() const; @@ -97,7 +97,7 @@ class SyncControl : public EngineControl, public Syncable { QString m_sGroup; // The only reason we have this pointer is an optimzation so that the // EngineSync can ask us what our EngineChannel is. EngineMaster in turn - // asks EngineSync what EngineChannel is the "master" channel. + // asks EngineSync what EngineChannel is the "leader" channel. EngineChannel* m_pChannel; SyncableListener* m_pEngineSync; BpmControl* m_pBpmControl; @@ -105,12 +105,12 @@ class SyncControl : public EngineControl, public Syncable { bool m_bOldScratching; // When syncing, sometimes it's better to match half or double the - // master bpm. + // leader bpm. FRIEND_TEST(EngineSyncTest, HalfDoubleBpmTest); FRIEND_TEST(EngineSyncTest, HalfDoubleThenPlay); - // The amount we should multiply the master BPM by to find a good sync match. + // The amount we should multiply the leader BPM by to find a good sync match. // Sometimes this is 2 or 0.5. - double m_masterBpmAdjustFactor; + double m_leaderBpmAdjustFactor; // It is handy to store the raw reported target beat distance in case the // multiplier changes and we need to recalculate the target distance. double m_unmultipliedTargetBeatDistance; @@ -118,7 +118,7 @@ class SyncControl : public EngineControl, public Syncable { QAtomicInt m_audible; QScopedPointer m_pSyncMode; - QScopedPointer m_pSyncMasterEnabled; + QScopedPointer m_pSyncLeaderEnabled; QScopedPointer m_pSyncEnabled; QScopedPointer m_pBeatDistance; diff --git a/src/mixer/basetrackplayer.cpp b/src/mixer/basetrackplayer.cpp index 63313d16e21..c9f0aff6fee 100644 --- a/src/mixer/basetrackplayer.cpp +++ b/src/mixer/basetrackplayer.cpp @@ -493,7 +493,7 @@ void BaseTrackPlayerImpl::slotTrackLoaded(TrackPointer pNewTrack, int reset = m_pConfig->getValue( ConfigKey("[Controls]", "SpeedAutoReset"), RESET_PITCH); if (reset == RESET_SPEED || reset == RESET_PITCH_AND_SPEED) { - // Avoid resetting speed if master sync is enabled and other decks with sync enabled + // Avoid resetting speed if sync lock is enabled and other decks with sync enabled // are playing, as this would change the speed of already playing decks. if (!m_pEngineMaster->getEngineSync()->otherSyncedPlaying(getGroup())) { m_pRateRatio->set(1.0); diff --git a/src/skin/legacy/tooltips.cpp b/src/skin/legacy/tooltips.cpp index 3540c5a43fb..eb83cf461aa 100644 --- a/src/skin/legacy/tooltips.cpp +++ b/src/skin/legacy/tooltips.cpp @@ -538,7 +538,7 @@ void Tooltips::addStandardTooltips() { // Ghetto-Sync (TM) add("beatsync_beatsync_tempo") << tr("Old Synchronize") - << tr("(This skin should be updated to use Master Sync!)") + << tr("(This skin should be updated to use Sync Lock!)") << QString("%1: %2").arg(leftClick, tr("Syncs the tempo (BPM) and phase to that of the other track, " "if BPM is detected on both.")) << QString("%1: %2").arg(rightClick, tr("Syncs the tempo (BPM) to that of the other track, " @@ -549,8 +549,8 @@ void Tooltips::addStandardTooltips() { // Awesome-Sync (TM) add("sync_enabled") - << tr("Enable Master Sync") - << tr("Tap to sync the tempo to other playing tracks or the master clock.") + << tr("Enable Sync Lock") + << tr("Tap to sync the tempo to other playing tracks or the sync leader.") << tr("Hold for at least a second to enable sync lock for this deck.") << tr("Decks with sync locked will all play at the same tempo, and decks that also have " "quantize enabled will always have their beats lined up."); @@ -562,9 +562,9 @@ void Tooltips::addStandardTooltips() { "from the other track. Requires a detected key on both involved decks.")) << QString("%1: %2").arg(rightClick, tr("Resets the key to the original track key.")); - add("sync_master") - << tr("Enable Sync Clock Master") - << tr("When enabled, this device will serve as the master clock for all other decks."); + add("sync_leader") + << tr("Enable Sync Leader") + << tr("When enabled, this device will serve as the sync leader for all other decks."); add("rate") << tr("Speed Control") diff --git a/src/test/co_dumps/co_dump_inital.csv b/src/test/co_dumps/co_dump_inital.csv index 119d94e8dc6..8f897b65b98 100644 --- a/src/test/co_dumps/co_dump_inital.csv +++ b/src/test/co_dumps/co_dump_inital.csv @@ -97,7 +97,7 @@ [EqualizerRack1_[Channel3]_Effect1],parameter1_type,2 [Sampler1],hotcue_17_gotoandplay,0 [PreviewDeck1],beatloop_32_activate,0 -[Channel1],sync_master,0 +[Channel1],sync_leader,0 [EffectRack1_EffectUnit4_Effect3],parameter1_link_type,0 [QuickEffectRack1_[Channel3]_Effect1],parameter6_toggle,0 [EffectRack1_EffectUnit3_Effect4],parameter3_minus_toggle,0 @@ -109,7 +109,7 @@ [QuickEffectRack1_[Channel1]_Effect1],parameter13_down,0 [Sampler2],hotcue_17_gotoandplay,0 [EffectRack1_EffectUnit3_Effect3],parameter14_set_minus_one,0 -[Channel2],sync_master,0 +[Channel2],sync_leader,0 [EffectRack1_EffectUnit4_Effect4],parameter1_link_type,0 [EffectRack1_EffectUnit3_Effect1],parameter5_minus_toggle,0 [EqualizerRack1_[Master]_Effect1],button_parameter10_loaded,0 @@ -170,7 +170,7 @@ [Sampler3],VuMeterL_up,0 [QuickEffectRack1_[Channel4]_Effect1],parameter3_set_zero,0 [Sampler3],hotcue_27_gotoandplay,0 -[Channel3],sync_master,0 +[Channel3],sync_leader,0 [QuickEffectRack1_[Channel3]_Effect1],parameter3_toggle,0 [EffectRack1_EffectUnit3_Effect2],parameter6_minus_toggle,0 [EqualizerRack1_[Channel3]_Effect1],parameter14_down,0 @@ -187,7 +187,7 @@ [Master],headGain_set_one,0 [Sampler4],hotcue_27_gotoandplay,0 [EffectRack1_EffectUnit4_Effect2],num_parameters,0 -[Channel4],sync_master,0 +[Channel4],sync_leader,0 [EffectRack1_EffectUnit3_Effect3],parameter9_minus_toggle,0 [EffectRack1_EffectUnit2_Effect2],parameter3_type,0 [Sampler4],hotcue_16_gotoandstop,0 @@ -343,7 +343,7 @@ [EffectRack1_EffectUnit3_Effect3],parameter6_minus_toggle,0 [EqualizerRack1_[Channel2]],mix_down,0 [EffectRack1_EffectUnit2_Effect2],button_parameter9_type,0 -[PreviewDeck1],sync_master,0 +[PreviewDeck1],sync_leader,0 [EffectRack1_EffectUnit4_Effect4],button_parameter11_type,0 [EqualizerRack1_[Channel4]_Effect1],button_parameter4_type,0 [PreviewDeck1],bpm_minus_toggle,0 @@ -9711,7 +9711,7 @@ [Microphone2],PeakIndicator_toggle,0 [EffectRack1_EffectUnit1_Effect2],parameter14_link_inverse,0 [EffectRack1_EffectUnit3_Effect3],button_parameter8_type,0 -[Sampler3],sync_master,0 +[Sampler3],sync_leader,0 [EqualizerRack1_[Master]_Effect1],button_parameter1,0 [QuickEffectRack1_[Channel1]_Effect1],parameter12_set_default,0 [Sampler1],rate_temp_down,0 @@ -9722,7 +9722,7 @@ [EffectRack1_EffectUnit3_Effect4],button_parameter8_type,0 [QuickEffectRack1_[Channel2]_Effect1],button_parameter9_type,0 [EqualizerRack1_[Channel3]],super1_set_minus_one,0 -[Sampler4],sync_master,0 +[Sampler4],sync_leader,0 [EffectRack1_EffectUnit4_Effect1],button_parameter5_type,0 [EqualizerRack1_[Channel4]_Effect1],button_parameter15,0 [PreviewDeck1],hotcue_23_gotoandplay,0 @@ -9737,7 +9737,7 @@ [Microphone4],PeakIndicator_toggle,0 [EffectRack1_EffectUnit3_Effect4],parameter14_link_inverse,0 [Sampler4],talkover,0 -[Sampler1],sync_master,0 +[Sampler1],sync_leader,0 [Channel4],beatloop_4_enabled,0 [EffectRack1_EffectUnit4_Effect2],button_parameter5_type,0 [QuickEffectRack1_[Channel1]_Effect1],parameter9,0 @@ -9759,7 +9759,7 @@ [PreviewDeck1],hotcue_20_activate_preview,0 [QuickEffectRack1_[Channel1]_Effect1],parameter2,0.707107 [EffectRack1_EffectUnit4_Effect4],parameter1_link_inverse,0 -[Sampler2],sync_master,0 +[Sampler2],sync_leader,0 [Channel3],beatloop_4_enabled,0 [EffectRack1_EffectUnit2_Effect3],parameter8_set_minus_one,0 [QuickEffectRack1_[Channel3]_Effect1],parameter1_down_small,0 @@ -9909,7 +9909,7 @@ [Channel3],hotcue_31_goto,0 [Playlist],LoadSelectedIntoFirstStopped,0 [Channel2],hotcue_1_activate_preview,0 -[InternalClock],sync_master,0 +[InternalClock],sync_leader,0 [EffectRack1_EffectUnit4_Effect1],parameter11_down_small,0 [Sampler3],rateSearch_set_minus_one,0 [EqualizerRack1_[Channel1]_Effect1],parameter11_up,0 diff --git a/src/test/enginesynctest.cpp b/src/test/enginesynctest.cpp index 29d5f124352..f5774e9d19c 100644 --- a/src/test/enginesynctest.cpp +++ b/src/test/enginesynctest.cpp @@ -20,50 +20,50 @@ constexpr double kMaxFloatingPointErrorHighPrecision = 0.0000000000000005; constexpr double kMaxBeatDistanceEpsilon = 1e-9; } // namespace -/// Tests for Master Sync. +/// Tests for Sync Lock. /// The following manual tests should probably be performed: -/// * Quantize mode nudges tracks in sync, whether internal or deck master. +/// * Quantize mode nudges tracks in sync, whether internal or deck leader. /// * Flinging tracks with the waveform should work. /// * vinyl?? class EngineSyncTest : public MockedEngineBackendTest { public: - QString getMasterGroup() { - Syncable* pMasterSyncable = m_pEngineSync->getMasterSyncable(); - if (pMasterSyncable) { - return pMasterSyncable->getGroup(); + QString getLeaderGroup() { + Syncable* pLeaderSyncable = m_pEngineSync->getLeaderSyncable(); + if (pLeaderSyncable) { + return pLeaderSyncable->getGroup(); } return QString(); } - bool isExplicitMaster(const QString& group) { - return isMaster(group, SYNC_MASTER_EXPLICIT); + bool isExplicitLeader(const QString& group) { + return isLeader(group, SyncMode::LeaderExplicit); } - bool isSoftMaster(const QString& group) { - return isMaster(group, SYNC_MASTER_SOFT); + bool isSoftLeader(const QString& group) { + return isLeader(group, SyncMode::LeaderSoft); } bool isFollower(const QString& group) { if (group == m_sInternalClockGroup) { return !ControlObject::getControl(ConfigKey(m_sInternalClockGroup, - "sync_master")) + "sync_leader")) ->toBool(); } if (auto mode = ControlObject::getControl(ConfigKey(group, "sync_mode")) ->get(); - mode != SYNC_FOLLOWER) { - qWarning() << "expected mode SYNC_FOLLOWER, got" << mode; + static_cast(mode) != SyncMode::Follower) { + qWarning() << "expected mode Follower, got" << mode; return false; } if (!ControlObject::getControl(ConfigKey(group, "sync_enabled"))->toBool()) { qWarning() << "sync_enabled should be on, isn't"; return false; } - if (double master = ControlObject::getControl( - ConfigKey(group, "sync_master")) + if (double leader = ControlObject::getControl( + ConfigKey(group, "sync_leader")) ->get(); - master != 0.0) { - qWarning() << "sync_master should be 0.0, is" << master; + leader != 0.0) { + qWarning() << "sync_leader should be 0.0, is" << leader; return false; } return true; @@ -73,115 +73,115 @@ class EngineSyncTest : public MockedEngineBackendTest { if (group == m_sInternalClockGroup) { EXPECT_EQ(0, ControlObject::getControl( - ConfigKey(m_sInternalClockGroup, "sync_master")) + ConfigKey(m_sInternalClockGroup, "sync_leader")) ->get()); } else { - EXPECT_EQ(SYNC_NONE, - ControlObject::getControl(ConfigKey(group, "sync_mode")) - ->get()); + EXPECT_EQ(SyncMode::None, + static_cast(ControlObject::getControl(ConfigKey(group, "sync_mode")) + ->get())); EXPECT_EQ(0, ControlObject::getControl(ConfigKey(group, "sync_enabled")) ->get()); EXPECT_EQ(0, - ControlObject::getControl(ConfigKey(group, "sync_master")) + ControlObject::getControl(ConfigKey(group, "sync_leader")) ->get()); } } - void assertNoMaster() { - EXPECT_EQ(NULL, m_pEngineSync->getMaster()); - EXPECT_EQ(NULL, m_pEngineSync->getMasterSyncable()); + void assertNoLeader() { + EXPECT_EQ(NULL, m_pEngineSync->getLeader()); + EXPECT_EQ(NULL, m_pEngineSync->getLeaderSyncable()); } private: - bool isMaster(const QString& group, SyncMode masterType) { + bool isLeader(const QString& group, SyncMode leaderType) { if (group == m_sInternalClockGroup) { - double master = ControlObject::getControl(ConfigKey(m_sInternalClockGroup, - "sync_master")) + double leader = ControlObject::getControl(ConfigKey(m_sInternalClockGroup, + "sync_leader")) ->get(); - if (masterType == SYNC_MASTER_SOFT && master != 1.0) { - qWarning() << "internal clock sync_master should be 1.0, is" << master; + if (leaderType == SyncMode::LeaderSoft && leader != 1.0) { + qWarning() << "internal clock sync_leader should be 1.0, is" << leader; return false; - } else if (masterType == SYNC_MASTER_EXPLICIT && master != 2.0) { - qWarning() << "internal clock sync_master should be 2.0, is" << master; + } else if (leaderType == SyncMode::LeaderExplicit && leader != 2.0) { + qWarning() << "internal clock sync_leader should be 2.0, is" << leader; return false; } - if (m_pEngineSync->getMaster()) { - qWarning() << "no current master"; + if (m_pEngineSync->getLeader()) { + qWarning() << "no current leader"; return false; } - if (m_sInternalClockGroup != getMasterGroup()) { - qWarning() << "internal clock is not master, it's" << getMasterGroup(); + if (m_sInternalClockGroup != getLeaderGroup()) { + qWarning() << "internal clock is not leader, it's" << getLeaderGroup(); return false; } return true; } if (group == m_sGroup1) { - if (m_pEngineSync->getMaster() != m_pChannel1) { - qWarning() << "master pointer should be channel 1, is " - << (m_pEngineSync->getMaster() - ? m_pEngineSync->getMaster() + if (m_pEngineSync->getLeader() != m_pChannel1) { + qWarning() << "leader pointer should be channel 1, is " + << (m_pEngineSync->getLeader() + ? m_pEngineSync->getLeader() ->getGroup() : "null"); return false; } } else if (group == m_sGroup2) { - if (m_pEngineSync->getMaster() != m_pChannel2) { - qWarning() << "master pointer should be channel 2, is " - << (m_pEngineSync->getMaster() - ? m_pEngineSync->getMaster() + if (m_pEngineSync->getLeader() != m_pChannel2) { + qWarning() << "leader pointer should be channel 2, is " + << (m_pEngineSync->getLeader() + ? m_pEngineSync->getLeader() ->getGroup() : "null"); return false; } } else if (group == m_sGroup3) { - if (m_pEngineSync->getMaster() != m_pChannel3) { - qWarning() << "master pointer should be channel 3, is " - << (m_pEngineSync->getMaster() - ? m_pEngineSync->getMaster() + if (m_pEngineSync->getLeader() != m_pChannel3) { + qWarning() << "leader pointer should be channel 3, is " + << (m_pEngineSync->getLeader() + ? m_pEngineSync->getLeader() ->getGroup() : "null"); return false; } } - if (getMasterGroup() != group) { - qWarning() << "master group should be" << group << ", is" << getMasterGroup(); + if (getLeaderGroup() != group) { + qWarning() << "leader group should be" << group << ", is" << getLeaderGroup(); return false; } if (auto mode = ControlObject::getControl(ConfigKey(group, "sync_mode")) ->get(); - mode != masterType) { - qWarning() << "mode should be" << masterType << ", is" << mode; + static_cast(mode) != leaderType) { + qWarning() << "mode should be" << leaderType << ", is" << mode; return false; } if (!ControlObject::getControl(ConfigKey(group, "sync_enabled"))->toBool()) { qWarning() << "sync_enabled should be true, isn't"; return false; } - switch (masterType) { - case SYNC_MASTER_SOFT: { - if (double master = ControlObject::getControl( - ConfigKey(group, "sync_master")) + switch (leaderType) { + case SyncMode::LeaderSoft: { + if (double leader = ControlObject::getControl( + ConfigKey(group, "sync_leader")) ->get(); - master != 1.0) { - qWarning() << "master should be 1.0, is" << master; + leader != 1.0) { + qWarning() << "leader should be 1.0, is" << leader; return false; } break; } - case SYNC_MASTER_EXPLICIT: { - if (double master = ControlObject::getControl( - ConfigKey(group, "sync_master")) + case SyncMode::LeaderExplicit: { + if (double leader = ControlObject::getControl( + ConfigKey(group, "sync_leader")) ->get(); - master != 2.0) { - qWarning() << "master should be 2.0, is" << master; + leader != 2.0) { + qWarning() << "leader should be 2.0, is" << leader; return false; } break; } default: - qWarning() << "bad master type specified"; + qWarning() << "bad leader type specified"; return false; } return true; @@ -194,46 +194,46 @@ TEST_F(EngineSyncTest, ControlObjectsExist) { NULL); } -TEST_F(EngineSyncTest, SetMasterSuccess) { - // If we set the first channel to master, EngineSync should get that message. +TEST_F(EngineSyncTest, SetLeaderSuccess) { + // If we set the first channel to leader, EngineSync should get that message. - auto pButtonMasterSync1 = + auto pButtonLeaderSync1 = std::make_unique(m_sGroup1, "sync_mode"); - pButtonMasterSync1->set(SYNC_MASTER_EXPLICIT); + pButtonLeaderSync1->set(static_cast(SyncMode::LeaderExplicit)); ProcessBuffer(); - // No tracks are playing and we have no beats, SYNC_MASTER_EXPLICIT state is in stand-by + // No tracks are playing and we have no beats, LeaderExplicit state is in stand-by EXPECT_DOUBLE_EQ( 0.0, ControlObject::getControl(ConfigKey(m_sGroup1, "bpm"))->get()); - // The master sync should now be internal clock, with group 1 waiting for play. + // The sync lock should now be internal clock, with group 1 waiting for play. EXPECT_TRUE(isFollower(m_sInternalClockGroup)); EXPECT_TRUE(isFollower(m_sGroup1)); - auto pButtonMasterSync2 = + auto pButtonLeaderSync2 = std::make_unique(m_sGroup2, "sync_mode"); - pButtonMasterSync2->set(SYNC_FOLLOWER); + pButtonLeaderSync2->set(static_cast(SyncMode::Follower)); ProcessBuffer(); EXPECT_TRUE(isFollower(m_sGroup2)); - // Now set channel 2 to be master. - pButtonMasterSync2->set(SYNC_MASTER_EXPLICIT); + // Now set channel 2 to be leader. + pButtonLeaderSync2->set(static_cast(SyncMode::LeaderExplicit)); ProcessBuffer(); - // Now channel 2 should be waiting master, and channel 1 should be a follower. + // Now channel 2 should be waiting leader, and channel 1 should be a follower. EXPECT_TRUE(isFollower(m_sGroup2)); EXPECT_TRUE(isFollower(m_sGroup1)); // Now back again. - pButtonMasterSync1->set(SYNC_MASTER_EXPLICIT); + pButtonLeaderSync1->set(static_cast(SyncMode::LeaderExplicit)); ProcessBuffer(); - // Now channel 1 should be waiting master, and channel 2 should be a follower. + // Now channel 1 should be waiting leader, and channel 2 should be a follower. EXPECT_TRUE(isFollower(m_sGroup1)); EXPECT_TRUE(isFollower(m_sGroup2)); // Now set channel 1 to follower, now all are followers, waiting for a tempo to adopt. - pButtonMasterSync1->set(SYNC_FOLLOWER); + pButtonLeaderSync1->set(static_cast(SyncMode::Follower)); ProcessBuffer(); EXPECT_TRUE(isFollower(m_sInternalClockGroup)); @@ -241,9 +241,9 @@ TEST_F(EngineSyncTest, SetMasterSuccess) { EXPECT_TRUE(isFollower(m_sGroup2)); } -TEST_F(EngineSyncTest, ExplicitMasterPersists) { - // If we set an explicit master, enabling sync or pressing play on other decks - // doesn't cause the master to move around. +TEST_F(EngineSyncTest, ExplicitLeaderPersists) { + // If we set an explicit leader, enabling sync or pressing play on other decks + // doesn't cause the leader to move around. mixxx::BeatsPointer pBeats1 = BeatFactory::makeBeatGrid( m_pTrack1->getSampleRate(), mixxx::Bpm(120), mixxx::audio::kStartFramePos); m_pTrack1->trySetBeats(pBeats1); @@ -251,20 +251,20 @@ TEST_F(EngineSyncTest, ExplicitMasterPersists) { m_pTrack2->getSampleRate(), mixxx::Bpm(124), mixxx::audio::kStartFramePos); m_pTrack2->trySetBeats(pBeats2); - auto pButtonMasterSync1 = + auto pButtonLeaderSync1 = std::make_unique(m_sGroup1, "sync_mode"); ControlObject::getControl(ConfigKey(m_sGroup1, "play"))->set(1.0); - pButtonMasterSync1->set(SYNC_MASTER_EXPLICIT); + pButtonLeaderSync1->set(static_cast(SyncMode::LeaderExplicit)); ProcessBuffer(); - // The master sync should now be channel 1. - EXPECT_TRUE(isExplicitMaster(m_sGroup1)); + // The sync lock should now be channel 1. + EXPECT_TRUE(isExplicitLeader(m_sGroup1)); - auto pButtonMasterSync2 = + auto pButtonLeaderSync2 = std::make_unique(m_sGroup2, "sync_enabled"); ControlObject::getControl(ConfigKey(m_sGroup2, "play"))->set(1.0); - pButtonMasterSync2->set(1.0); + pButtonLeaderSync2->set(1.0); ProcessBuffer(); - EXPECT_TRUE(isExplicitMaster(m_sGroup1)); + EXPECT_TRUE(isExplicitLeader(m_sGroup1)); EXPECT_TRUE(isFollower(m_sGroup2)); // Stop deck 2, and restart it, no change. @@ -272,12 +272,12 @@ TEST_F(EngineSyncTest, ExplicitMasterPersists) { ProcessBuffer(); ControlObject::getControl(ConfigKey(m_sGroup2, "play"))->set(1.0); ProcessBuffer(); - EXPECT_TRUE(isExplicitMaster(m_sGroup1)); + EXPECT_TRUE(isExplicitLeader(m_sGroup1)); EXPECT_TRUE(isFollower(m_sGroup2)); } -TEST_F(EngineSyncTest, SetMasterWhilePlaying) { - // Make sure we don't get two master lights if we change masters while playing. +TEST_F(EngineSyncTest, SetLeaderWhilePlaying) { + // Make sure we don't get two leader lights if we change leaders while playing. mixxx::BeatsPointer pBeats1 = BeatFactory::makeBeatGrid( m_pTrack1->getSampleRate(), mixxx::Bpm(120), mixxx::audio::kStartFramePos); m_pTrack1->trySetBeats(pBeats1); @@ -288,15 +288,15 @@ TEST_F(EngineSyncTest, SetMasterWhilePlaying) { m_pTrack3->getSampleRate(), mixxx::Bpm(128), mixxx::audio::kStartFramePos); m_pTrack3->trySetBeats(pBeats3); - auto pButtonMasterSync1 = + auto pButtonLeaderSync1 = std::make_unique(m_sGroup1, "sync_mode"); - pButtonMasterSync1->set(SYNC_MASTER_EXPLICIT); - auto pButtonMasterSync2 = + pButtonLeaderSync1->set(static_cast(SyncMode::LeaderExplicit)); + auto pButtonLeaderSync2 = std::make_unique(m_sGroup2, "sync_mode"); - pButtonMasterSync2->set(SYNC_FOLLOWER); - auto pButtonMasterSync3 = + pButtonLeaderSync2->set(static_cast(SyncMode::Follower)); + auto pButtonLeaderSync3 = std::make_unique(m_sGroup3, "sync_mode"); - pButtonMasterSync3->set(SYNC_FOLLOWER); + pButtonLeaderSync3->set(static_cast(SyncMode::Follower)); ControlObject::getControl(ConfigKey(m_sGroup1, "play"))->set(1.0); ControlObject::getControl(ConfigKey(m_sGroup2, "play"))->set(1.0); @@ -304,42 +304,42 @@ TEST_F(EngineSyncTest, SetMasterWhilePlaying) { ProcessBuffer(); - pButtonMasterSync3->set(SYNC_MASTER_EXPLICIT); + pButtonLeaderSync3->set(static_cast(SyncMode::LeaderExplicit)); ProcessBuffer(); EXPECT_TRUE(isFollower(m_sGroup1)); EXPECT_TRUE(isFollower(m_sGroup2)); - EXPECT_TRUE(isExplicitMaster(m_sGroup3)); + EXPECT_TRUE(isExplicitLeader(m_sGroup3)); } -TEST_F(EngineSyncTest, SetEnabledBecomesMaster) { - // If we set the first channel with a valid tempo to follower, it should be master. +TEST_F(EngineSyncTest, SetEnabledBecomesLeader) { + // If we set the first channel with a valid tempo to follower, it should be leader. mixxx::BeatsPointer pBeats1 = BeatFactory::makeBeatGrid( m_pTrack1->getSampleRate(), mixxx::Bpm(80), mixxx::audio::kStartFramePos); m_pTrack1->trySetBeats(pBeats1); - auto pButtonMasterSync1 = + auto pButtonLeaderSync1 = std::make_unique(m_sGroup1, "sync_mode"); - pButtonMasterSync1->set(SYNC_FOLLOWER); + pButtonLeaderSync1->set(static_cast(SyncMode::Follower)); ProcessBuffer(); - EXPECT_TRUE(isSoftMaster(m_sGroup1)); + EXPECT_TRUE(isSoftLeader(m_sGroup1)); EXPECT_TRUE(isFollower(m_sInternalClockGroup)); } -TEST_F(EngineSyncTest, DisableInternalMasterWhilePlaying) { - auto pButtonMasterSync = std::make_unique( - m_sInternalClockGroup, "sync_master"); - pButtonMasterSync->set(1.0); +TEST_F(EngineSyncTest, DisableInternalLeaderWhilePlaying) { + auto pButtonLeaderSync = std::make_unique( + m_sInternalClockGroup, "sync_leader"); + pButtonLeaderSync->set(1.0); auto pButtonSyncMode1 = std::make_unique(m_sGroup1, "sync_mode"); - pButtonSyncMode1->set(SYNC_FOLLOWER); + pButtonSyncMode1->set(static_cast(SyncMode::Follower)); auto pButtonSyncMode2 = std::make_unique(m_sGroup2, "sync_mode"); - pButtonSyncMode2->set(SYNC_FOLLOWER); + pButtonSyncMode2->set(static_cast(SyncMode::Follower)); ProcessBuffer(); - // The master sync should now be Internal. - EXPECT_TRUE(isExplicitMaster(m_sInternalClockGroup)); + // The sync lock should now be Internal. + EXPECT_TRUE(isExplicitLeader(m_sInternalClockGroup)); // Make sure both decks are playing. mixxx::BeatsPointer pBeats1 = BeatFactory::makeBeatGrid( @@ -352,70 +352,70 @@ TEST_F(EngineSyncTest, DisableInternalMasterWhilePlaying) { ControlObject::getControl(ConfigKey(m_sGroup2, "play"))->set(1.0); ProcessBuffer(); - // Now unset Internal master. - pButtonMasterSync->set(0.0); + // Now unset Internal leader. + pButtonLeaderSync->set(0.0); ProcessBuffer(); - // This is not allowed, Internal should still be master. + // This is not allowed, Internal should still be leader. EXPECT_TRUE(isFollower(m_sInternalClockGroup)); - EXPECT_EQ(0, pButtonMasterSync->get()); + EXPECT_EQ(0, pButtonLeaderSync->get()); } -TEST_F(EngineSyncTest, DisableSyncOnMaster) { - // Channel 1 follower, channel 2 master. +TEST_F(EngineSyncTest, DisableSyncOnLeader) { + // Channel 1 follower, channel 2 leader. mixxx::BeatsPointer pBeats1 = BeatFactory::makeBeatGrid( m_pTrack1->getSampleRate(), mixxx::Bpm(130), mixxx::audio::kStartFramePos); m_pTrack1->trySetBeats(pBeats1); auto pButtonSyncMode1 = std::make_unique(m_sGroup1, "sync_mode"); - pButtonSyncMode1->set(SYNC_FOLLOWER); + pButtonSyncMode1->set(static_cast(SyncMode::Follower)); mixxx::BeatsPointer pBeats2 = BeatFactory::makeBeatGrid( m_pTrack2->getSampleRate(), mixxx::Bpm(130), mixxx::audio::kStartFramePos); m_pTrack2->trySetBeats(pBeats2); - // Set deck two to explicit master. - auto pButtonSyncMaster2 = - std::make_unique(m_sGroup2, "sync_master"); - pButtonSyncMaster2->set(1.0); + // Set deck two to explicit leader. + auto pButtonSyncLeader2 = + std::make_unique(m_sGroup2, "sync_leader"); + pButtonSyncLeader2->set(1.0); ProcessBuffer(); EXPECT_TRUE(isFollower(m_sGroup1)); - EXPECT_TRUE(isExplicitMaster(m_sGroup2)); + EXPECT_TRUE(isExplicitLeader(m_sGroup2)); - // Set deck 2 to playing, now it becomes explicit master. + // Set deck 2 to playing, now it becomes explicit leader. ControlObject::getControl(ConfigKey(m_sGroup2, "play"))->set(1.0); - // The request to become master is queued, so we have to process a buffer. + // The request to become leader is queued, so we have to process a buffer. ProcessBuffer(); EXPECT_TRUE(isFollower(m_sGroup1)); - EXPECT_TRUE(isExplicitMaster(m_sGroup2)); + EXPECT_TRUE(isExplicitLeader(m_sGroup2)); // Unset enabled on channel2, it should work. auto pButtonSyncEnabled2 = std::make_unique(m_sGroup2, "sync_enabled"); pButtonSyncEnabled2->set(0.0); ProcessBuffer(); - EXPECT_TRUE(isSoftMaster(m_sGroup1)); + EXPECT_TRUE(isSoftLeader(m_sGroup1)); EXPECT_EQ(0, ControlObject::getControl(ConfigKey(m_sGroup2, "sync_enabled"))->get()); - EXPECT_EQ(0, ControlObject::getControl(ConfigKey(m_sGroup2, "sync_master"))->get()); + EXPECT_EQ(0, ControlObject::getControl(ConfigKey(m_sGroup2, "sync_leader"))->get()); } -TEST_F(EngineSyncTest, InternalMasterSetFollowerSliderMoves) { - // If internal is master, and we turn on a follower, the slider should move. - auto pButtonMasterSyncInternal = std::make_unique( - m_sInternalClockGroup, "sync_master"); - auto pMasterSyncSlider = +TEST_F(EngineSyncTest, InternalLeaderSetFollowerSliderMoves) { + // If internal is leader, and we turn on a follower, the slider should move. + auto pButtonLeaderSyncInternal = std::make_unique( + m_sInternalClockGroup, "sync_leader"); + auto pLeaderSyncSlider = std::make_unique(m_sInternalClockGroup, "bpm"); - pMasterSyncSlider->set(100.0); - pButtonMasterSyncInternal->set(1); + pLeaderSyncSlider->set(100.0); + pButtonLeaderSyncInternal->set(1); // Set the file bpm of channel 1 to 80 bpm. mixxx::BeatsPointer pBeats1 = BeatFactory::makeBeatGrid( m_pTrack1->getSampleRate(), mixxx::Bpm(80), mixxx::audio::kStartFramePos); m_pTrack1->trySetBeats(pBeats1); - auto pButtonMasterSync1 = + auto pButtonLeaderSync1 = std::make_unique(m_sGroup1, "sync_mode"); - pButtonMasterSync1->set(SYNC_FOLLOWER); + pButtonLeaderSync1->set(static_cast(SyncMode::Follower)); ProcessBuffer(); EXPECT_DOUBLE_EQ(getRateSliderValue(1.25), @@ -426,7 +426,7 @@ TEST_F(EngineSyncTest, InternalMasterSetFollowerSliderMoves) { TEST_F(EngineSyncTest, AnySyncDeckSliderStays) { // If there exists a sync deck, even if it's not playing, don't change the - // master BPM if a new deck enables sync. + // leader BPM if a new deck enables sync. mixxx::BeatsPointer pBeats1 = BeatFactory::makeBeatGrid( m_pTrack1->getSampleRate(), mixxx::Bpm(80), mixxx::audio::kStartFramePos); @@ -455,9 +455,9 @@ TEST_F(EngineSyncTest, AnySyncDeckSliderStays) { TEST_F(EngineSyncTest, InternalClockFollowsFirstPlayingDeck) { // Same as above, except we use the midi lights to change state. - auto pButtonMasterSync1 = + auto pButtonLeaderSync1 = std::make_unique(m_sGroup1, "sync_mode"); - auto pButtonMasterSync2 = + auto pButtonLeaderSync2 = std::make_unique(m_sGroup2, "sync_mode"); auto pButtonSyncEnabled1 = std::make_unique(m_sGroup1, "sync_enabled"); @@ -481,8 +481,8 @@ TEST_F(EngineSyncTest, InternalClockFollowsFirstPlayingDeck) { pButtonSyncEnabled1->set(1.0); ProcessBuffer(); - // The master sync should now be deck 1. - EXPECT_TRUE(isSoftMaster(m_sGroup1)); + // The sync lock should now be deck 1. + EXPECT_TRUE(isSoftLeader(m_sGroup1)); EXPECT_DOUBLE_EQ(130.0, ControlObject::get(ConfigKey(m_sInternalClockGroup, "bpm"))); @@ -490,8 +490,8 @@ TEST_F(EngineSyncTest, InternalClockFollowsFirstPlayingDeck) { pButtonSyncEnabled2->set(1); ProcessBuffer(); - // channel 1 still master while 2 is not playing - EXPECT_TRUE(isSoftMaster(m_sGroup1)); + // channel 1 still leader while 2 is not playing + EXPECT_TRUE(isSoftLeader(m_sGroup1)); EXPECT_TRUE(isFollower(m_sInternalClockGroup)); EXPECT_TRUE(isFollower(m_sGroup2)); @@ -503,17 +503,17 @@ TEST_F(EngineSyncTest, InternalClockFollowsFirstPlayingDeck) { ControlObject::set(ConfigKey(m_sGroup2, "rate"), getRateSliderValue(1.0)); ControlObject::set(ConfigKey(m_sGroup2, "play"), 1.0); ProcessBuffer(); - // Deck 1 still master + // Deck 1 still leader EXPECT_TRUE(isFollower(m_sInternalClockGroup)); - EXPECT_TRUE(isSoftMaster(m_sGroup1)); + EXPECT_TRUE(isSoftLeader(m_sGroup1)); EXPECT_TRUE(isFollower(m_sGroup2)); // Now disable sync on channel 1. pButtonSyncEnabled1->set(0); ProcessBuffer(); - // Master flips to deck 2 - EXPECT_TRUE(isSoftMaster(m_sGroup2)); + // Leader flips to deck 2 + EXPECT_TRUE(isSoftLeader(m_sGroup2)); EXPECT_TRUE(isFollower(m_sInternalClockGroup)); // Rate should now match channel 2. @@ -521,20 +521,20 @@ TEST_F(EngineSyncTest, InternalClockFollowsFirstPlayingDeck) { 130.0, ControlObject::get(ConfigKey(m_sInternalClockGroup, "bpm"))); } -TEST_F(EngineSyncTest, SetExplicitMasterByLights) { +TEST_F(EngineSyncTest, SetExplicitLeaderByLights) { // Same as above, except we use the midi lights to change state. - auto pButtonMasterSync1 = + auto pButtonLeaderSync1 = std::make_unique(m_sGroup1, "sync_mode"); - auto pButtonMasterSync2 = + auto pButtonLeaderSync2 = std::make_unique(m_sGroup2, "sync_mode"); auto pButtonSyncEnabled1 = std::make_unique(m_sGroup1, "sync_enabled"); auto pButtonSyncEnabled2 = std::make_unique(m_sGroup2, "sync_enabled"); - auto pButtonSyncMaster1 = - std::make_unique(m_sGroup1, "sync_master"); - auto pButtonSyncMaster2 = - std::make_unique(m_sGroup2, "sync_master"); + auto pButtonSyncLeader1 = + std::make_unique(m_sGroup1, "sync_leader"); + auto pButtonSyncLeader2 = + std::make_unique(m_sGroup2, "sync_leader"); // Set the file bpm of channel 1 to 160bpm. mixxx::BeatsPointer pBeats1 = BeatFactory::makeBeatGrid( @@ -548,12 +548,12 @@ TEST_F(EngineSyncTest, SetExplicitMasterByLights) { ControlObject::set(ConfigKey(m_sGroup1, "play"), 1.0); ControlObject::set(ConfigKey(m_sGroup2, "play"), 1.0); - // Set channel 1 to be explicit master. - pButtonSyncMaster1->set(1.0); + // Set channel 1 to be explicit leader. + pButtonSyncLeader1->set(1.0); ProcessBuffer(); - // The master sync should now be channel 1. - EXPECT_TRUE(isExplicitMaster(m_sGroup1)); + // The sync lock should now be channel 1. + EXPECT_TRUE(isExplicitLeader(m_sGroup1)); // Set channel 2 to be follower. pButtonSyncEnabled2->set(1); @@ -561,49 +561,49 @@ TEST_F(EngineSyncTest, SetExplicitMasterByLights) { EXPECT_TRUE(isFollower(m_sGroup2)); - // Now set channel 2 to be master. - pButtonSyncMaster2->set(1); + // Now set channel 2 to be leader. + pButtonSyncLeader2->set(1); ProcessBuffer(); - // Now channel 2 should be master, and channel 1 should be a follower. + // Now channel 2 should be leader, and channel 1 should be a follower. EXPECT_TRUE(isFollower(m_sGroup1)); - EXPECT_TRUE(isExplicitMaster(m_sGroup2)); + EXPECT_TRUE(isExplicitLeader(m_sGroup2)); // Now back again. - pButtonSyncMaster1->set(1); + pButtonSyncLeader1->set(1); ProcessBuffer(); - // Now channel 1 should be master, and channel 2 should be a follower. - EXPECT_TRUE(isExplicitMaster(m_sGroup1)); + // Now channel 1 should be leader, and channel 2 should be a follower. + EXPECT_TRUE(isExplicitLeader(m_sGroup1)); EXPECT_TRUE(isFollower(m_sGroup2)); - // Now set channel 1 to not-master. The system will choose deck 2 as the next best - // option for soft master - pButtonSyncMaster1->set(0); + // Now set channel 1 to not-leader. The system will choose deck 2 as the next best + // option for soft leader + pButtonSyncLeader1->set(0); ProcessBuffer(); EXPECT_TRUE(isFollower(m_sInternalClockGroup)); - EXPECT_TRUE(isSoftMaster(m_sGroup1)); + EXPECT_TRUE(isSoftLeader(m_sGroup1)); EXPECT_TRUE(isFollower(m_sGroup2)); } -TEST_F(EngineSyncTest, SetExplicitMasterByLightsNoTracks) { +TEST_F(EngineSyncTest, SetExplicitLeaderByLightsNoTracks) { // Same as above, except we use the midi lights to change state. auto pButtonSyncEnabled2 = std::make_unique(m_sGroup2, "sync_enabled"); - auto pButtonSyncMaster1 = - std::make_unique(m_sGroup1, "sync_master"); + auto pButtonSyncLeader1 = + std::make_unique(m_sGroup1, "sync_leader"); - pButtonSyncMaster1->set(1); + pButtonSyncLeader1->set(1); // Set channel 2 to be follower. pButtonSyncEnabled2->set(1); - // Without a track loaded, deck 1 can't be an explicit master. + // Without a track loaded, deck 1 can't be an explicit leader. EXPECT_TRUE(isFollower(m_sGroup1)); EXPECT_TRUE(isFollower(m_sGroup2)); - pButtonSyncMaster1->set(0); + pButtonSyncLeader1->set(0); EXPECT_TRUE(isFollower(m_sGroup1)); EXPECT_TRUE(isFollower(m_sGroup2)); @@ -611,12 +611,12 @@ TEST_F(EngineSyncTest, SetExplicitMasterByLightsNoTracks) { } TEST_F(EngineSyncTest, RateChangeTest) { - auto pButtonMasterSync1 = + auto pButtonLeaderSync1 = std::make_unique(m_sGroup1, "sync_mode"); - pButtonMasterSync1->set(SYNC_MASTER_EXPLICIT); - auto pButtonMasterSync2 = + pButtonLeaderSync1->set(static_cast(SyncMode::LeaderExplicit)); + auto pButtonLeaderSync2 = std::make_unique(m_sGroup2, "sync_mode"); - pButtonMasterSync2->set(SYNC_FOLLOWER); + pButtonLeaderSync2->set(static_cast(SyncMode::Follower)); ProcessBuffer(); // Set the file bpm of channel 1 to 160bpm. @@ -635,7 +635,7 @@ TEST_F(EngineSyncTest, RateChangeTest) { ControlObject::get(ConfigKey(m_sGroup1, "rate"))); EXPECT_DOUBLE_EQ(192.0, ControlObject::get(ConfigKey(m_sGroup1, "bpm"))); - // Internal master should also be 192. + // Internal leader should also be 192. EXPECT_DOUBLE_EQ( 192.0, ControlObject::get(ConfigKey(m_sInternalClockGroup, "bpm"))); @@ -654,12 +654,12 @@ TEST_F(EngineSyncTest, RateChangeTest) { TEST_F(EngineSyncTest, RateChangeTestWeirdOrder) { // This is like the test above, but the user loads the track after the slider has been tweaked. - auto pButtonMasterSync1 = + auto pButtonLeaderSync1 = std::make_unique(m_sGroup1, "sync_mode"); - pButtonMasterSync1->set(SYNC_MASTER_EXPLICIT); - auto pButtonMasterSync2 = + pButtonLeaderSync1->set(static_cast(SyncMode::LeaderExplicit)); + auto pButtonLeaderSync2 = std::make_unique(m_sGroup2, "sync_mode"); - pButtonMasterSync2->set(SYNC_FOLLOWER); + pButtonLeaderSync2->set(static_cast(SyncMode::Follower)); ProcessBuffer(); // Set the file bpm of channel 1 to 160bpm. @@ -682,7 +682,7 @@ TEST_F(EngineSyncTest, RateChangeTestWeirdOrder) { ControlObject::get(ConfigKey(m_sGroup2, "rate"))); EXPECT_DOUBLE_EQ(192.0, ControlObject::get(ConfigKey(m_sGroup2, "bpm"))); - // Internal Master BPM should read the same. + // Internal Leader BPM should read the same. EXPECT_DOUBLE_EQ( 192.0, ControlObject::get(ConfigKey(m_sInternalClockGroup, "bpm"))); } @@ -702,19 +702,19 @@ TEST_F(EngineSyncTest, RateChangeTestOrder3) { EXPECT_DOUBLE_EQ( 120.0, ControlObject::get(ConfigKey(m_sGroup2, "file_bpm"))); - // Turn on Master. Setting explicit master causes this track's rate to be adopted instead + // Turn on Leader. Setting explicit leader causes this track's rate to be adopted instead // of matching against the other deck. - auto pButtonMasterSync1 = + auto pButtonLeaderSync1 = std::make_unique(m_sGroup1, "sync_mode"); - pButtonMasterSync1->set(SYNC_MASTER_EXPLICIT); + pButtonLeaderSync1->set(static_cast(SyncMode::LeaderExplicit)); ProcessBuffer(); - EXPECT_TRUE(isExplicitMaster(m_sGroup1)); + EXPECT_TRUE(isExplicitLeader(m_sGroup1)); EXPECT_DOUBLE_EQ(160.0, ControlObject::get(ConfigKey(m_sGroup1, "bpm"))); // Turn on follower. - auto pButtonMasterSync2 = + auto pButtonLeaderSync2 = std::make_unique(m_sGroup2, "sync_mode"); - pButtonMasterSync2->set(SYNC_FOLLOWER); + pButtonLeaderSync2->set(static_cast(SyncMode::Follower)); ProcessBuffer(); // Follower should immediately set its slider. @@ -727,13 +727,13 @@ TEST_F(EngineSyncTest, RateChangeTestOrder3) { } TEST_F(EngineSyncTest, FollowerRateChange) { - // Confirm that followers can change master sync rate as well. - auto pButtonMasterSync1 = + // Confirm that followers can change sync lock rate as well. + auto pButtonLeaderSync1 = std::make_unique(m_sGroup1, "sync_mode"); - pButtonMasterSync1->set(SYNC_MASTER_EXPLICIT); - auto pButtonMasterSync2 = + pButtonLeaderSync1->set(static_cast(SyncMode::LeaderExplicit)); + auto pButtonLeaderSync2 = std::make_unique(m_sGroup2, "sync_mode"); - pButtonMasterSync2->set(SYNC_FOLLOWER); + pButtonLeaderSync2->set(static_cast(SyncMode::Follower)); ProcessBuffer(); // Set the file bpm of channel 1 to 160bpm. @@ -769,18 +769,18 @@ TEST_F(EngineSyncTest, FollowerRateChange) { } TEST_F(EngineSyncTest, InternalRateChangeTest) { - auto pButtonMasterSyncInternal = std::make_unique( - m_sInternalClockGroup, "sync_master"); - pButtonMasterSyncInternal->set(1.0); - auto pButtonMasterSync1 = + auto pButtonLeaderSyncInternal = std::make_unique( + m_sInternalClockGroup, "sync_leader"); + pButtonLeaderSyncInternal->set(1.0); + auto pButtonLeaderSync1 = std::make_unique(m_sGroup1, "sync_mode"); - pButtonMasterSync1->set(SYNC_FOLLOWER); - auto pButtonMasterSync2 = + pButtonLeaderSync1->set(static_cast(SyncMode::Follower)); + auto pButtonLeaderSync2 = std::make_unique(m_sGroup2, "sync_mode"); - pButtonMasterSync2->set(SYNC_FOLLOWER); + pButtonLeaderSync2->set(static_cast(SyncMode::Follower)); ProcessBuffer(); - EXPECT_TRUE(isExplicitMaster(m_sInternalClockGroup)); + EXPECT_TRUE(isExplicitLeader(m_sInternalClockGroup)); EXPECT_TRUE(isFollower(m_sGroup1)); EXPECT_TRUE(isFollower(m_sGroup2)); @@ -799,9 +799,9 @@ TEST_F(EngineSyncTest, InternalRateChangeTest) { ControlObject::getControl(ConfigKey(m_sGroup2, "file_bpm"))->get()); // Set the internal rate to 150. - auto pMasterSyncSlider = + auto pLeaderSyncSlider = std::make_unique(m_sInternalClockGroup, "bpm"); - pMasterSyncSlider->set(150.0); + pLeaderSyncSlider->set(150.0); EXPECT_DOUBLE_EQ(150.0, ControlObject::getControl(ConfigKey(m_sInternalClockGroup, "bpm")) ->get()); @@ -820,7 +820,7 @@ TEST_F(EngineSyncTest, InternalRateChangeTest) { ControlObject::getControl(ConfigKey(m_sGroup2, "bpm"))->get()); // Set the internal rate to 140. - pMasterSyncSlider->set(140.0); + pLeaderSyncSlider->set(140.0); // Update COs again. ProcessBuffer(); @@ -837,8 +837,8 @@ TEST_F(EngineSyncTest, InternalRateChangeTest) { ControlObject::getControl(ConfigKey(m_sGroup2, "bpm"))->get()); } -TEST_F(EngineSyncTest, MasterStopSliderCheck) { - // If the master is playing, and stop is pushed, the sliders should stay the same. +TEST_F(EngineSyncTest, LeaderStopSliderCheck) { + // If the leader is playing, and stop is pushed, the sliders should stay the same. mixxx::BeatsPointer pBeats1 = BeatFactory::makeBeatGrid( m_pTrack1->getSampleRate(), mixxx::Bpm(120), mixxx::audio::kStartFramePos); m_pTrack1->trySetBeats(pBeats1); @@ -846,15 +846,15 @@ TEST_F(EngineSyncTest, MasterStopSliderCheck) { m_pTrack2->getSampleRate(), mixxx::Bpm(128), mixxx::audio::kStartFramePos); m_pTrack2->trySetBeats(pBeats2); - auto pButtonMasterSync1 = + auto pButtonLeaderSync1 = std::make_unique(m_sGroup1, "sync_mode"); - pButtonMasterSync1->set(SYNC_MASTER_EXPLICIT); - auto pButtonMasterSync2 = + pButtonLeaderSync1->set(static_cast(SyncMode::LeaderExplicit)); + auto pButtonLeaderSync2 = std::make_unique(m_sGroup2, "sync_mode"); - pButtonMasterSync2->set(SYNC_FOLLOWER); + pButtonLeaderSync2->set(static_cast(SyncMode::Follower)); ProcessBuffer(); - //EXPECT_TRUE(isExplicitMaster(m_sGroup1)); + //EXPECT_TRUE(isExplicitLeader(m_sGroup1)); EXPECT_TRUE(isFollower(m_sGroup2)); auto pChannel1Play = std::make_unique(m_sGroup1, "play"); @@ -877,9 +877,9 @@ TEST_F(EngineSyncTest, MasterStopSliderCheck) { ControlObject::get(ConfigKey(m_sGroup2, "rate"))); } -TEST_F(EngineSyncTest, EnableOneDeckInitsMaster) { - // If Internal is master, and we turn sync on a playing deck, the playing deck sets the - // internal master and the beat distances are now aligned. +TEST_F(EngineSyncTest, EnableOneDeckInitsLeader) { + // If Internal is leader, and we turn sync on a playing deck, the playing deck sets the + // internal leader and the beat distances are now aligned. ControlObject::set(ConfigKey(m_sInternalClockGroup, "bpm"), 124.0); ControlObject::set(ConfigKey(m_sInternalClockGroup, "beat_distance"), 0.5); ProcessBuffer(); @@ -896,10 +896,10 @@ TEST_F(EngineSyncTest, EnableOneDeckInitsMaster) { // Enable Sync. We have to call requestEnableSync directly // because calling ProcessBuffer() tries to advance the beat_distance values. m_pEngineSync->requestSyncMode( - m_pEngineSync->getSyncableForGroup(m_sGroup1), SYNC_FOLLOWER); + m_pEngineSync->getSyncableForGroup(m_sGroup1), SyncMode::Follower); - // Internal is no longer master because there is exactly one playing deck. - EXPECT_TRUE(isSoftMaster(m_sGroup1)); + // Internal is no longer leader because there is exactly one playing deck. + EXPECT_TRUE(isSoftLeader(m_sGroup1)); EXPECT_TRUE(isFollower(m_sInternalClockGroup)); // Internal clock rate and beat distance should match that deck. @@ -922,10 +922,10 @@ TEST_F(EngineSyncTest, EnableOneDeckInitsMaster) { ControlObject::getControl(ConfigKey(m_sGroup2, "play"))->set(1.0); m_pEngineSync->requestSyncMode( - m_pEngineSync->getSyncableForGroup(m_sGroup2), SYNC_FOLLOWER); - // Deck 1 is still soft master. + m_pEngineSync->getSyncableForGroup(m_sGroup2), SyncMode::Follower); + // Deck 1 is still soft leader. EXPECT_TRUE(isFollower(m_sInternalClockGroup)); - EXPECT_TRUE(isSoftMaster(m_sGroup1)); + EXPECT_TRUE(isSoftLeader(m_sGroup1)); EXPECT_TRUE(isFollower(m_sGroup2)); EXPECT_DOUBLE_EQ( @@ -961,8 +961,8 @@ TEST_F(EngineSyncTest, MomentarySyncAlgorithmTwo) { EXPECT_DOUBLE_EQ(128.0, ControlObject::get(ConfigKey(m_sGroup1, "bpm"))); } -TEST_F(EngineSyncTest, EnableOneDeckInitializesMaster) { - // Enabling sync on a deck causes it to be master, and sets bpm and clock. +TEST_F(EngineSyncTest, EnableOneDeckInitializesLeader) { + // Enabling sync on a deck causes it to be leader, and sets bpm and clock. // Set the deck to play. mixxx::BeatsPointer pBeats1 = BeatFactory::makeBeatGrid( m_pTrack1->getSampleRate(), mixxx::Bpm(130), mixxx::audio::kStartFramePos); @@ -975,10 +975,10 @@ TEST_F(EngineSyncTest, EnableOneDeckInitializesMaster) { // Set the deck to follower. // As above, use direct call to avoid advancing beat distance. m_pEngineSync->requestSyncMode( - m_pEngineSync->getSyncableForGroup(m_sGroup1), SYNC_FOLLOWER); + m_pEngineSync->getSyncableForGroup(m_sGroup1), SyncMode::Follower); - // That first deck is now master - EXPECT_TRUE(isSoftMaster(m_sGroup1)); + // That first deck is now leader + EXPECT_TRUE(isSoftLeader(m_sGroup1)); // Internal clock rate should be set and beat distances reset. EXPECT_DOUBLE_EQ(130.0, @@ -995,7 +995,7 @@ TEST_F(EngineSyncTest, EnableOneDeckInitializesMaster) { ->get()); } -TEST_F(EngineSyncTest, LoadTrackInitializesMaster) { +TEST_F(EngineSyncTest, LoadTrackInitializesLeader) { // First eject the fake tracks that come with the testing framework. m_pChannel1->getEngineBuffer()->slotEjectTrack(1.0); m_pChannel2->getEngineBuffer()->slotEjectTrack(1.0); @@ -1005,24 +1005,24 @@ TEST_F(EngineSyncTest, LoadTrackInitializesMaster) { std::make_unique(m_sGroup1, "sync_enabled"); pButtonSyncEnabled1->set(1.0); - // No master because this deck has no track. - EXPECT_EQ(NULL, m_pEngineSync->getMaster()); + // No leader because this deck has no track. + EXPECT_EQ(NULL, m_pEngineSync->getLeader()); EXPECT_DOUBLE_EQ( 0.0, ControlObject::getControl(ConfigKey(m_sGroup1, "bpm"))->get()); - // The track load trigger a master change. + // The track load trigger a leader change. m_pMixerDeck1->loadFakeTrack(false, 140.0); - EXPECT_TRUE(isSoftMaster(m_sGroup1)); + EXPECT_TRUE(isSoftLeader(m_sGroup1)); EXPECT_DOUBLE_EQ(140.0, ControlObject::getControl(ConfigKey(m_sGroup1, "bpm"))->get()); - // But as soon as we play, deck 1 is master + // But as soon as we play, deck 1 is leader ControlObject::getControl(ConfigKey(m_sGroup1, "play"))->set(1.0); - EXPECT_TRUE(isSoftMaster(m_sGroup1)); + EXPECT_TRUE(isSoftLeader(m_sGroup1)); ControlObject::getControl(ConfigKey(m_sGroup1, "play"))->set(0.0); // If sync is on two decks and we load a track in only one of them, it will be - // master. + // leader. m_pChannel1->getEngineBuffer()->slotEjectTrack(1.0); EXPECT_TRUE(isFollower(m_sGroup1)); // no relevant tempo available so internal clock is following @@ -1034,13 +1034,13 @@ TEST_F(EngineSyncTest, LoadTrackInitializesMaster) { m_pMixerDeck1->loadFakeTrack(false, 128.0); - // Deck 2 is still empty so Deck 1 becomes master again - EXPECT_TRUE(isSoftMaster(m_sGroup1)); + // Deck 2 is still empty so Deck 1 becomes leader again + EXPECT_TRUE(isSoftLeader(m_sGroup1)); EXPECT_DOUBLE_EQ(128.0, ControlObject::getControl(ConfigKey(m_sGroup1, "bpm"))->get()); // If sync is on two decks and one deck is loaded but not playing, we should - // initialize to that deck with internal clock master. + // initialize to that deck with internal clock leader. m_pMixerDeck2->loadFakeTrack(false, 110.0); EXPECT_TRUE(isFollower(m_sInternalClockGroup)); @@ -1054,9 +1054,9 @@ TEST_F(EngineSyncTest, LoadTrackInitializesMaster) { } TEST_F(EngineSyncTest, LoadTrackResetTempoOption) { - // Make sure playing decks with master sync enabled do not change tempo when + // Make sure playing decks with sync lock enabled do not change tempo when // the "Reset Speed/Tempo" preference is set and a track is loaded to another - // deck with master sync enabled. + // deck with sync lock enabled. m_pConfig->set(ConfigKey("[Controls]", "SpeedAutoReset"), ConfigValue(BaseTrackPlayer::RESET_SPEED)); @@ -1069,13 +1069,13 @@ TEST_F(EngineSyncTest, LoadTrackResetTempoOption) { std::make_unique(m_sGroup2, "sync_enabled"); pButtonSyncEnabled2->set(1.0); - // If sync is on and we load a track, that should initialize master. + // If sync is on and we load a track, that should initialize leader. TrackPointer track1 = m_pMixerDeck1->loadFakeTrack(false, 140.0); EXPECT_DOUBLE_EQ( 140.0, ControlObject::get(ConfigKey(m_sInternalClockGroup, "bpm"))); EXPECT_DOUBLE_EQ(140.0, ControlObject::get(ConfigKey(m_sGroup1, "bpm"))); - EXPECT_TRUE(isSoftMaster(m_sGroup1)); + EXPECT_TRUE(isSoftLeader(m_sGroup1)); // If sync is on two decks and we load a track while one is playing, // that should not change the playing deck. @@ -1151,7 +1151,7 @@ TEST_F(EngineSyncTest, LoadTrackResetTempoOption) { } TEST_F(EngineSyncTest, EnableOneDeckSliderUpdates) { - // If we enable a deck to be master, the internal slider should immediately update. + // If we enable a deck to be leader, the internal slider should immediately update. auto pButtonSyncEnabled1 = std::make_unique(m_sGroup1, "sync_enabled"); @@ -1165,8 +1165,8 @@ TEST_F(EngineSyncTest, EnableOneDeckSliderUpdates) { pButtonSyncEnabled1->set(1.0); ProcessBuffer(); - // Group 1 should now be master (only one sync deck). - EXPECT_TRUE(isSoftMaster(m_sGroup1)); + // Group 1 should now be leader (only one sync deck). + EXPECT_TRUE(isSoftLeader(m_sGroup1)); // Internal clock rate should be set. EXPECT_DOUBLE_EQ(130.0, @@ -1202,9 +1202,9 @@ TEST_F(EngineSyncTest, SyncToNonSyncDeck) { pButtonSyncEnabled2->set(0.0); ProcessBuffer(); - // There should be no master, and deck2 should match rate of deck1. Sync slider should be + // There should be no leader, and deck2 should match rate of deck1. Sync slider should be // updated with the value, however. - assertNoMaster(); + assertNoLeader(); EXPECT_DOUBLE_EQ( 130.0, ControlObject::get(ConfigKey(m_sInternalClockGroup, "bpm"))); assertSyncOff(m_sGroup2); @@ -1219,17 +1219,18 @@ TEST_F(EngineSyncTest, SyncToNonSyncDeck) { pButtonSyncEnabled1->set(0.0); ProcessBuffer(); - // There should be no master, and deck2 should match rate of deck1. + // There should be no leader, and deck2 should match rate of deck1. EXPECT_EQ(0, ControlObject::get( - ConfigKey(m_sInternalClockGroup, "sync_master"))); + ConfigKey(m_sInternalClockGroup, "sync_leader"))); EXPECT_DOUBLE_EQ( 100.0, ControlObject::get(ConfigKey(m_sInternalClockGroup, "bpm"))); - EXPECT_EQ(NULL, m_pEngineSync->getMaster()); - EXPECT_EQ(NULL, m_pEngineSync->getMasterSyncable()); - EXPECT_EQ(SYNC_NONE, ControlObject::get(ConfigKey(m_sGroup1, "sync_mode"))); + EXPECT_EQ(NULL, m_pEngineSync->getLeader()); + EXPECT_EQ(NULL, m_pEngineSync->getLeaderSyncable()); + EXPECT_EQ(static_cast(SyncMode::None), + ControlObject::get(ConfigKey(m_sGroup1, "sync_mode"))); EXPECT_EQ(0, ControlObject::get(ConfigKey(m_sGroup1, "sync_enabled"))); - EXPECT_EQ(0, ControlObject::get(ConfigKey(m_sGroup1, "sync_master"))); + EXPECT_EQ(0, ControlObject::get(ConfigKey(m_sGroup1, "sync_leader"))); EXPECT_DOUBLE_EQ(getRateSliderValue(100.0 / 130.0), ControlObject::get(ConfigKey(m_sGroup1, "rate"))); @@ -1244,17 +1245,18 @@ TEST_F(EngineSyncTest, SyncToNonSyncDeck) { pButtonSyncEnabled1->set(0.0); ProcessBuffer(); - // There should be no master, and deck2 should match rate of deck1. + // There should be no leader, and deck2 should match rate of deck1. EXPECT_EQ(0, ControlObject::get( - ConfigKey(m_sInternalClockGroup, "sync_master"))); + ConfigKey(m_sInternalClockGroup, "sync_leader"))); EXPECT_DOUBLE_EQ( 100.0, ControlObject::get(ConfigKey(m_sInternalClockGroup, "bpm"))); - EXPECT_EQ(NULL, m_pEngineSync->getMaster()); - EXPECT_EQ(NULL, m_pEngineSync->getMasterSyncable()); - EXPECT_EQ(SYNC_NONE, ControlObject::get(ConfigKey(m_sGroup2, "sync_mode"))); + EXPECT_EQ(NULL, m_pEngineSync->getLeader()); + EXPECT_EQ(NULL, m_pEngineSync->getLeaderSyncable()); + EXPECT_EQ(static_cast(SyncMode::None), + ControlObject::get(ConfigKey(m_sGroup2, "sync_mode"))); EXPECT_EQ(0, ControlObject::get(ConfigKey(m_sGroup2, "sync_enabled"))); - EXPECT_EQ(0, ControlObject::get(ConfigKey(m_sGroup2, "sync_master"))); + EXPECT_EQ(0, ControlObject::get(ConfigKey(m_sGroup2, "sync_leader"))); EXPECT_DOUBLE_EQ(getRateSliderValue(1.0), ControlObject::get(ConfigKey(m_sGroup2, "rate"))); } @@ -1287,8 +1289,8 @@ TEST_F(EngineSyncTest, MomentarySyncDependsOnPlayingStates) { pButtonSyncEnabled1->set(0.0); ProcessBuffer(); - // The master sync should still be off and the speed should match deck 2. - assertNoMaster(); + // The sync lock should still be off and the speed should match deck 2. + assertNoLeader(); assertSyncOff(m_sGroup1); assertSyncOff(m_sGroup2); EXPECT_DOUBLE_EQ( @@ -1302,7 +1304,7 @@ TEST_F(EngineSyncTest, MomentarySyncDependsOnPlayingStates) { pButtonSyncEnabled1->set(1.0); pButtonSyncEnabled1->set(0.0); ProcessBuffer(); - assertNoMaster(); + assertNoLeader(); assertSyncOff(m_sGroup1); assertSyncOff(m_sGroup2); EXPECT_DOUBLE_EQ( @@ -1316,7 +1318,7 @@ TEST_F(EngineSyncTest, MomentarySyncDependsOnPlayingStates) { pButtonSyncEnabled1->set(1.0); pButtonSyncEnabled1->set(0.0); ProcessBuffer(); - assertNoMaster(); + assertNoLeader(); assertSyncOff(m_sGroup1); assertSyncOff(m_sGroup2); EXPECT_DOUBLE_EQ( @@ -1331,7 +1333,7 @@ TEST_F(EngineSyncTest, MomentarySyncDependsOnPlayingStates) { pButtonSyncEnabled1->set(1.0); pButtonSyncEnabled1->set(0.0); ProcessBuffer(); - assertNoMaster(); + assertNoLeader(); assertSyncOff(m_sGroup1); assertSyncOff(m_sGroup2); EXPECT_DOUBLE_EQ( @@ -1353,7 +1355,7 @@ TEST_F(EngineSyncTest, EjectTrackSyncRemains) { // m_sGroup1 takes over EXPECT_TRUE(isFollower(m_sInternalClockGroup)); - EXPECT_TRUE(isSoftMaster(m_sGroup1)); + EXPECT_TRUE(isSoftLeader(m_sGroup1)); assertSyncOff(m_sGroup2); pButtonEject1->set(1.0); @@ -1378,7 +1380,7 @@ TEST_F(EngineSyncTest, EjectTrackSyncRemains) { ProcessBuffer(); EXPECT_TRUE(isFollower(m_sInternalClockGroup)); - EXPECT_TRUE(isSoftMaster(m_sGroup1)); + EXPECT_TRUE(isSoftLeader(m_sGroup1)); EXPECT_TRUE(isFollower(m_sGroup2)); pButtonEject1->set(1.0); @@ -1387,11 +1389,11 @@ TEST_F(EngineSyncTest, EjectTrackSyncRemains) { EXPECT_TRUE(isFollower(m_sInternalClockGroup)); EXPECT_TRUE(isFollower(m_sGroup1)); - EXPECT_TRUE(isSoftMaster(m_sGroup2)); + EXPECT_TRUE(isSoftLeader(m_sGroup2)); } -TEST_F(EngineSyncTest, FileBpmChangesDontAffectMaster) { - // If filebpm changes, don't treat it like a rate change unless it's the master. +TEST_F(EngineSyncTest, FileBpmChangesDontAffectLeader) { + // If filebpm changes, don't treat it like a rate change unless it's the leader. mixxx::BeatsPointer pBeats1 = BeatFactory::makeBeatGrid( m_pTrack1->getSampleRate(), mixxx::Bpm(100), mixxx::audio::kStartFramePos); m_pTrack1->trySetBeats(pBeats1); @@ -1408,17 +1410,17 @@ TEST_F(EngineSyncTest, FileBpmChangesDontAffectMaster) { pButtonSyncEnabled2->set(1.0); ProcessBuffer(); - EXPECT_TRUE(isSoftMaster(m_sGroup1)); + EXPECT_TRUE(isSoftLeader(m_sGroup1)); EXPECT_TRUE(isFollower(m_sGroup2)); - // Update the master's beats -- update the internal clock + // Update the leader's beats -- update the internal clock pBeats1 = BeatFactory::makeBeatGrid( m_pTrack1->getSampleRate(), mixxx::Bpm(160), mixxx::audio::kStartFramePos); m_pTrack1->trySetBeats(pBeats1); EXPECT_DOUBLE_EQ( 160.0, ControlObject::get(ConfigKey(m_sInternalClockGroup, "bpm"))); - EXPECT_TRUE(isSoftMaster(m_sGroup1)); + EXPECT_TRUE(isSoftLeader(m_sGroup1)); // Update follower beats -- don't update internal clock. pBeats2 = BeatFactory::makeBeatGrid( @@ -1428,12 +1430,12 @@ TEST_F(EngineSyncTest, FileBpmChangesDontAffectMaster) { 160.0, ControlObject::get(ConfigKey(m_sInternalClockGroup, "bpm"))); } -TEST_F(EngineSyncTest, ExplicitMasterPostProcessed) { - // Regression test thanks to a bug. Make sure that an explicit master +TEST_F(EngineSyncTest, ExplicitLeaderPostProcessed) { + // Regression test thanks to a bug. Make sure that an explicit leader // channel gets post-processed. - auto pButtonMasterSync1 = + auto pButtonLeaderSync1 = std::make_unique(m_sGroup1, "sync_mode"); - pButtonMasterSync1->set(SYNC_MASTER_EXPLICIT); + pButtonLeaderSync1->set(static_cast(SyncMode::LeaderExplicit)); mixxx::BeatsPointer pBeats1 = BeatFactory::makeBeatGrid( m_pTrack1->getSampleRate(), mixxx::Bpm(160), mixxx::audio::kStartFramePos); m_pTrack1->trySetBeats(pBeats1); @@ -1473,10 +1475,10 @@ TEST_F(EngineSyncTest, ZeroBPMRateAdjustIgnored) { EXPECT_DOUBLE_EQ(getRateSliderValue(1.0), ControlObject::getControl(ConfigKey(m_sGroup2, "rate"))->get()); - // Also try with explicit master/follower setting + // Also try with explicit leader/follower setting pButtonSyncEnabled1->set(0.0); ControlObject::getControl(ConfigKey(m_sGroup1, "sync_mode")) - ->set(SYNC_MASTER_EXPLICIT); + ->set(static_cast(SyncMode::LeaderExplicit)); ControlObject::getControl(ConfigKey(m_sGroup1, "rate")) ->set(getRateSliderValue(1.4)); @@ -1485,7 +1487,7 @@ TEST_F(EngineSyncTest, ZeroBPMRateAdjustIgnored) { pButtonSyncEnabled1->set(0.0); ControlObject::getControl(ConfigKey(m_sGroup1, "sync_mode")) - ->set(SYNC_FOLLOWER); + ->set(static_cast(SyncMode::Follower)); ControlObject::getControl(ConfigKey(m_sGroup1, "rate")) ->set(getRateSliderValue(0.9)); @@ -1514,7 +1516,7 @@ TEST_F(EngineSyncTest, BeatDistanceBeforeStart) { } TEST_F(EngineSyncTest, ZeroLatencyRateChangeNoQuant) { - // Confirm that a rate change in an explicit master is instantly communicated + // Confirm that a rate change in an explicit leader is instantly communicated // to followers. mixxx::BeatsPointer pBeats1 = BeatFactory::makeBeatGrid( m_pTrack1->getSampleRate(), mixxx::Bpm(128), mixxx::audio::kStartFramePos); @@ -1523,11 +1525,11 @@ TEST_F(EngineSyncTest, ZeroLatencyRateChangeNoQuant) { m_pTrack2->getSampleRate(), mixxx::Bpm(160), mixxx::audio::kStartFramePos); m_pTrack2->trySetBeats(pBeats2); - // Make Channel2 master to weed out any channel ordering issues. + // Make Channel2 leader to weed out any channel ordering issues. ControlObject::getControl(ConfigKey(m_sGroup2, "sync_mode")) - ->set(SYNC_FOLLOWER); + ->set(static_cast(SyncMode::Follower)); ControlObject::getControl(ConfigKey(m_sGroup1, "sync_mode")) - ->set(SYNC_FOLLOWER); + ->set(static_cast(SyncMode::Follower)); // Exaggerate the effect with a high rate. ControlObject::set(ConfigKey(m_sGroup2, "rate_ratio"), 10.0); @@ -1564,7 +1566,7 @@ TEST_F(EngineSyncTest, ZeroLatencyRateChangeNoQuant) { } TEST_F(EngineSyncTest, ZeroLatencyRateChangeQuant) { - // Confirm that a rate change in an explicit master is instantly communicated + // Confirm that a rate change in an explicit leader is instantly communicated // to followers. mixxx::BeatsPointer pBeats1 = BeatFactory::makeBeatGrid( m_pTrack1->getSampleRate(), mixxx::Bpm(128), mixxx::audio::kStartFramePos); @@ -1576,11 +1578,11 @@ TEST_F(EngineSyncTest, ZeroLatencyRateChangeQuant) { ControlObject::getControl(ConfigKey(m_sGroup1, "quantize"))->set(1.0); ControlObject::getControl(ConfigKey(m_sGroup2, "quantize"))->set(1.0); - // Make Channel2 master to weed out any channel ordering issues. + // Make Channel2 leader to weed out any channel ordering issues. ControlObject::getControl(ConfigKey(m_sGroup2, "sync_mode")) - ->set(SYNC_FOLLOWER); + ->set(static_cast(SyncMode::Follower)); ControlObject::getControl(ConfigKey(m_sGroup1, "sync_mode")) - ->set(SYNC_FOLLOWER); + ->set(static_cast(SyncMode::Follower)); // Exaggerate the effect with a high rate. ControlObject::set(ConfigKey(m_sGroup2, "rate_ratio"), 10.0); @@ -1619,7 +1621,7 @@ TEST_F(EngineSyncTest, ZeroLatencyRateChangeQuant) { } TEST_F(EngineSyncTest, ZeroLatencyRateDiffQuant) { - // Confirm that a rate change in an explicit master is instantly communicated + // Confirm that a rate change in an explicit leader is instantly communicated // to followers. mixxx::BeatsPointer pBeats1 = BeatFactory::makeBeatGrid( m_pTrack1->getSampleRate(), mixxx::Bpm(128), mixxx::audio::kStartFramePos); @@ -1630,11 +1632,11 @@ TEST_F(EngineSyncTest, ZeroLatencyRateDiffQuant) { ControlObject::getControl(ConfigKey(m_sGroup2, "quantize"))->set(1.0); - // Make Channel2 master to weed out any channel ordering issues. + // Make Channel2 leader to weed out any channel ordering issues. ControlObject::getControl(ConfigKey(m_sGroup2, "sync_mode")) - ->set(SYNC_FOLLOWER); + ->set(static_cast(SyncMode::Follower)); ControlObject::getControl(ConfigKey(m_sGroup1, "sync_mode")) - ->set(SYNC_FOLLOWER); + ->set(static_cast(SyncMode::Follower)); // Exaggerate the effect with a high rate. ControlObject::set(ConfigKey(m_sGroup2, "rate_ratio"), 10.0); @@ -1672,7 +1674,7 @@ TEST_F(EngineSyncTest, ZeroLatencyRateDiffQuant) { kMaxBeatDistanceEpsilon); } -// In this test, we set play *first* and then turn on master sync. +// In this test, we set play *first* and then turn on sync lock. // This exercises a slightly different ordering of signals that we // need to check. The Sync feature is unfortunately brittle. // This test exercises https://bugs.launchpad.net/mixxx/+bug/1884324 @@ -1698,13 +1700,13 @@ TEST_F(EngineSyncTest, ActivatingSyncDoesNotCauseDrifting) { ControlObject::getControl(ConfigKey(m_sGroup1, "beat_distance")) ->get()); - // engage first sync-master + // engage first sync-leader ControlObject::getControl(ConfigKey(m_sGroup1, "sync_mode")) - ->set(SYNC_FOLLOWER); + ->set(static_cast(SyncMode::Follower)); - // engage second Sync-master + // engage second Sync-leader ControlObject::getControl(ConfigKey(m_sGroup2, "sync_mode")) - ->set(SYNC_FOLLOWER); + ->set(static_cast(SyncMode::Follower)); // Run for a number of buffers for (int i = 0; i < 25; ++i) { @@ -1730,7 +1732,7 @@ TEST_F(EngineSyncTest, HalfDoubleBpmTest) { m_pTrack2->getSampleRate(), mixxx::Bpm(140), mixxx::audio::kStartFramePos); m_pTrack2->trySetBeats(pBeats2); - // Mixxx will choose the first playing deck to be master. Let's start deck 2 first. + // Mixxx will choose the first playing deck to be leader. Let's start deck 2 first. ControlObject::getControl(ConfigKey(m_sGroup1, "volume"))->set(1.0); ControlObject::getControl(ConfigKey(m_sGroup2, "volume"))->set(1.0); ProcessBuffer(); @@ -1743,15 +1745,15 @@ TEST_F(EngineSyncTest, HalfDoubleBpmTest) { ControlObject::getControl(ConfigKey(m_sGroup1, "play"))->set(1.0); ProcessBuffer(); - ASSERT_TRUE(isSoftMaster(m_sGroup2)); + ASSERT_TRUE(isSoftLeader(m_sGroup2)); ASSERT_TRUE(isFollower(m_sGroup1)); EXPECT_EQ(0.5, m_pChannel1->getEngineBuffer() - ->m_pSyncControl->m_masterBpmAdjustFactor); + ->m_pSyncControl->m_leaderBpmAdjustFactor); EXPECT_EQ(1.0, m_pChannel2->getEngineBuffer() - ->m_pSyncControl->m_masterBpmAdjustFactor); + ->m_pSyncControl->m_leaderBpmAdjustFactor); EXPECT_DOUBLE_EQ( m_pChannel1->getEngineBuffer()->m_pSyncControl->getBeatDistance(), m_pChannel2->getEngineBuffer()->m_pSyncControl->getBeatDistance()); @@ -1775,21 +1777,21 @@ TEST_F(EngineSyncTest, HalfDoubleBpmTest) { ControlObject::getControl(ConfigKey(m_sGroup2, "play"))->set(0.0); ControlObject::getControl(ConfigKey(m_sGroup1, "sync_mode")) - ->set(SYNC_NONE); + ->set(static_cast(SyncMode::None)); ControlObject::getControl(ConfigKey(m_sGroup2, "sync_mode")) - ->set(SYNC_NONE); + ->set(static_cast(SyncMode::None)); EXPECT_EQ(1.0, m_pChannel1->getEngineBuffer() - ->m_pSyncControl->m_masterBpmAdjustFactor); + ->m_pSyncControl->m_leaderBpmAdjustFactor); EXPECT_EQ(1.0, m_pChannel2->getEngineBuffer() - ->m_pSyncControl->m_masterBpmAdjustFactor); + ->m_pSyncControl->m_leaderBpmAdjustFactor); ControlObject::getControl(ConfigKey(m_sGroup1, "sync_mode")) - ->set(SYNC_FOLLOWER); + ->set(static_cast(SyncMode::Follower)); ControlObject::getControl(ConfigKey(m_sGroup2, "sync_mode")) - ->set(SYNC_FOLLOWER); + ->set(static_cast(SyncMode::Follower)); ControlObject::getControl(ConfigKey(m_sGroup1, "rate")) ->set(getRateSliderValue(1.0)); @@ -1801,10 +1803,10 @@ TEST_F(EngineSyncTest, HalfDoubleBpmTest) { EXPECT_EQ(1.0, m_pChannel1->getEngineBuffer() - ->m_pSyncControl->m_masterBpmAdjustFactor); + ->m_pSyncControl->m_leaderBpmAdjustFactor); EXPECT_EQ(2.0, m_pChannel2->getEngineBuffer() - ->m_pSyncControl->m_masterBpmAdjustFactor); + ->m_pSyncControl->m_leaderBpmAdjustFactor); // Exaggerate the effect with a high rate. ControlObject::getControl(ConfigKey(m_sGroup2, "rate")) @@ -1842,16 +1844,16 @@ TEST_F(EngineSyncTest, HalfDoubleThenPlay) { ControlObject::getControl(ConfigKey(m_sGroup1, "quantize"))->set(1.0); ControlObject::getControl(ConfigKey(m_sGroup2, "quantize"))->set(1.0); - // We expect that m_sGroup1 has adjusted its own bpm to the second deck and becomes a single master. + // We expect that m_sGroup1 has adjusted its own bpm to the second deck and becomes a single leader. // The internal clock is initialized right away. - EXPECT_TRUE(isSoftMaster(m_sGroup1)); + EXPECT_TRUE(isSoftLeader(m_sGroup1)); EXPECT_TRUE(isFollower(m_sGroup2)); EXPECT_DOUBLE_EQ(1.0, m_pChannel1->getEngineBuffer() - ->m_pSyncControl->m_masterBpmAdjustFactor); + ->m_pSyncControl->m_leaderBpmAdjustFactor); EXPECT_DOUBLE_EQ(2.0, m_pChannel2->getEngineBuffer() - ->m_pSyncControl->m_masterBpmAdjustFactor); + ->m_pSyncControl->m_leaderBpmAdjustFactor); EXPECT_DOUBLE_EQ(87.5, ControlObject::getControl(ConfigKey(m_sInternalClockGroup, "bpm")) ->get()); @@ -1903,10 +1905,10 @@ TEST_F(EngineSyncTest, HalfDoubleThenPlay) { pButtonSyncEnabled1->set(1.0); EXPECT_DOUBLE_EQ(0.5, m_pChannel1->getEngineBuffer() - ->m_pSyncControl->m_masterBpmAdjustFactor); + ->m_pSyncControl->m_leaderBpmAdjustFactor); EXPECT_DOUBLE_EQ(1.0, m_pChannel2->getEngineBuffer() - ->m_pSyncControl->m_masterBpmAdjustFactor); + ->m_pSyncControl->m_leaderBpmAdjustFactor); ControlObject::getControl(ConfigKey(m_sGroup1, "play"))->set(1.0); ControlObject::getControl(ConfigKey(m_sGroup2, "play"))->set(1.0); @@ -1956,7 +1958,7 @@ TEST_F(EngineSyncTest, HalfDoubleInternalClockTest) { ControlObject::getControl(ConfigKey(m_sGroup1, "quantize"))->set(1.0); ControlObject::getControl(ConfigKey(m_sGroup2, "quantize"))->set(1.0); - // Make Channel2 master to weed out any channel ordering issues. + // Make Channel2 leader to weed out any channel ordering issues. ControlObject::getControl(ConfigKey(m_sGroup1, "sync_enabled"))->set(1); ControlObject::getControl(ConfigKey(m_sGroup2, "sync_enabled"))->set(1); @@ -2101,7 +2103,7 @@ TEST_F(EngineSyncTest, SyncPhaseToPlayingNonSyncDeck) { m_pTrack2->trySetBeats(pBeats2); // Set the sync deck playing with nothing else active. - // Next Deck becomes master and the Master clock is set to 100 BPM + // Next Deck becomes leader and the Leader clock is set to 100 BPM // The 130 BPM Track should be played at 100 BPM, rate = 0.769230769 pButtonSyncEnabled1->set(1.0); ControlObject::getControl(ConfigKey(m_sGroup1, "play"))->set(1.0); @@ -2130,7 +2132,7 @@ TEST_F(EngineSyncTest, SyncPhaseToPlayingNonSyncDeck) { // we expect that Deck 1 distance has not changed but the internal clock keeps going, because // the internal clock should continue playing even if the leader is stopped. - EXPECT_TRUE(isSoftMaster(m_sGroup1)); + EXPECT_TRUE(isSoftLeader(m_sGroup1)); EXPECT_NEAR(0.019349962, ControlObject::getControl(ConfigKey(m_sGroup1, "beat_distance"))->get(), kMaxFloatingPointErrorLowPrecision); @@ -2149,7 +2151,7 @@ TEST_F(EngineSyncTest, SyncPhaseToPlayingNonSyncDeck) { // The first deck is still the only one with sync active. // TODO: It does sounds odd to start the track 1 at a random position and adjust the // phase later. Seeking into phase is the best option even with quantize off. - EXPECT_TRUE(isSoftMaster(m_sGroup1)); + EXPECT_TRUE(isSoftLeader(m_sGroup1)); EXPECT_DOUBLE_EQ(100.0, ControlObject::getControl(ConfigKey(m_sGroup1, "bpm"))->get()); // The adjustment is calculated here: BpmControl::calcSyncAdjustment @@ -2185,7 +2187,7 @@ TEST_F(EngineSyncTest, SyncPhaseToPlayingNonSyncDeck) { m_pTrack3->trySetBeats(pBeats3); // This will sync to the first deck here and not the second (lp1784185) pButtonSyncEnabled3->set(1.0); - EXPECT_TRUE(isSoftMaster(m_sGroup3)); + EXPECT_TRUE(isSoftLeader(m_sGroup3)); ProcessBuffer(); EXPECT_DOUBLE_EQ(130.0, ControlObject::get(ConfigKey(m_sGroup3, "bpm"))); // revert that @@ -2196,9 +2198,9 @@ TEST_F(EngineSyncTest, SyncPhaseToPlayingNonSyncDeck) { pButtonSyncEnabled1->set(1.0); ProcessBuffer(); - // Soft master is now deck one because that was the last one we enabled and none of them + // Soft leader is now deck one because that was the last one we enabled and none of them // are playing. - EXPECT_TRUE(isSoftMaster(m_sGroup1)); + EXPECT_TRUE(isSoftLeader(m_sGroup1)); ControlObject::getControl(ConfigKey(m_sGroup3, "play"))->set(1.0); ControlObject::getControl(ConfigKey(m_sGroup2, "play"))->set(1.0); @@ -2224,7 +2226,7 @@ TEST_F(EngineSyncTest, SyncPhaseToPlayingNonSyncDeck) { TEST_F(EngineSyncTest, UserTweakBeatDistance) { // If a deck has a user tweak, and another deck stops such that the first - // is used to reseed the master beat distance, make sure the user offset + // is used to reseed the leader beat distance, make sure the user offset // is reset. mixxx::BeatsPointer pBeats1 = BeatFactory::makeBeatGrid( m_pTrack1->getSampleRate(), mixxx::Bpm(128), mixxx::audio::kStartFramePos); @@ -2257,7 +2259,7 @@ TEST_F(EngineSyncTest, UserTweakBeatDistance) { ProcessBuffer(); } - // Stop the second deck. This causes the master beat distance to get + // Stop the second deck. This causes the leader beat distance to get // seeded with the beat distance from deck 1. ControlObject::getControl(ConfigKey(m_sGroup2, "play"))->set(0.0); @@ -2277,7 +2279,7 @@ TEST_F(EngineSyncTest, UserTweakBeatDistance) { } TEST_F(EngineSyncTest, UserTweakPreservedInSeek) { - // Ensure that when we do a seek during master sync, the user offset is maintained. + // Ensure that when we do a seek during sync lock, the user offset is maintained. // This is about 128 bpm, but results in nice round numbers of samples. const double kDivisibleBpm = 44100.0 / 344.0; @@ -2356,9 +2358,9 @@ TEST_F(EngineSyncTest, UserTweakPreservedInSeek) { kMaxFloatingPointErrorLowPrecision); } -TEST_F(EngineSyncTest, FollowerUserTweakPreservedInMasterChange) { - // Ensure that when the master deck changes, the user offset is accounted for when - // reinitializing the master parameters.. +TEST_F(EngineSyncTest, FollowerUserTweakPreservedInLeaderChange) { + // Ensure that when the leader deck changes, the user offset is accounted for when + // reinitializing the leader parameters.. // This is about 128 bpm, but results in nice round numbers of samples. const double kDivisibleBpm = 44100.0 / 344.0; @@ -2369,7 +2371,7 @@ TEST_F(EngineSyncTest, FollowerUserTweakPreservedInMasterChange) { m_pTrack2->getSampleRate(), mixxx::Bpm(130), mixxx::audio::kStartFramePos); m_pTrack2->trySetBeats(pBeats2); - ControlObject::getControl(ConfigKey(m_sGroup1, "sync_master"))->set(1); + ControlObject::getControl(ConfigKey(m_sGroup1, "sync_leader"))->set(1); ControlObject::getControl(ConfigKey(m_sGroup2, "sync_enabled"))->set(1); ControlObject::set(ConfigKey(m_sGroup1, "quantize"), 1.0); ControlObject::set(ConfigKey(m_sGroup2, "quantize"), 1.0); @@ -2379,7 +2381,7 @@ TEST_F(EngineSyncTest, FollowerUserTweakPreservedInMasterChange) { ControlObject::set(ConfigKey(m_sGroup1, "play"), 1.0); ControlObject::set(ConfigKey(m_sGroup2, "play"), 1.0); - EXPECT_TRUE(isExplicitMaster(m_sGroup1)); + EXPECT_TRUE(isExplicitLeader(m_sGroup1)); EXPECT_TRUE(isFollower(m_sGroup2)); ProcessBuffer(); @@ -2395,11 +2397,11 @@ TEST_F(EngineSyncTest, FollowerUserTweakPreservedInMasterChange) { kMaxFloatingPointErrorLowPrecision); } - // Switch master - ControlObject::getControl(ConfigKey(m_sGroup2, "sync_master"))->set(1); + // Switch leader + ControlObject::getControl(ConfigKey(m_sGroup2, "sync_leader"))->set(1); ProcessBuffer(); EXPECT_TRUE(isFollower(m_sGroup1)); - EXPECT_TRUE(isExplicitMaster(m_sGroup2)); + EXPECT_TRUE(isExplicitLeader(m_sGroup2)); for (int i = 0; i < 10; ++i) { ProcessBuffer(); @@ -2409,9 +2411,9 @@ TEST_F(EngineSyncTest, FollowerUserTweakPreservedInMasterChange) { } } -TEST_F(EngineSyncTest, MasterUserTweakPreservedInMasterChange) { - // Ensure that when the master deck changes, the user offset is accounted for when - // reinitializing the master parameters.. +TEST_F(EngineSyncTest, LeaderUserTweakPreservedInLeaderChange) { + // Ensure that when the leader deck changes, the user offset is accounted for when + // reinitializing the leader parameters.. // This is about 128 bpm, but results in nice round numbers of samples. const double kDivisibleBpm = 44100.0 / 344.0; @@ -2422,14 +2424,14 @@ TEST_F(EngineSyncTest, MasterUserTweakPreservedInMasterChange) { m_pTrack2->getSampleRate(), mixxx::Bpm(130), mixxx::audio::kStartFramePos); m_pTrack2->trySetBeats(pBeats2); - ControlObject::getControl(ConfigKey(m_sGroup1, "sync_master"))->set(1); + ControlObject::getControl(ConfigKey(m_sGroup1, "sync_leader"))->set(1); ControlObject::getControl(ConfigKey(m_sGroup2, "sync_enabled"))->set(1); ControlObject::set(ConfigKey(m_sGroup1, "quantize"), 1.0); ControlObject::set(ConfigKey(m_sGroup2, "quantize"), 1.0); ControlObject::set(ConfigKey(m_sGroup1, "play"), 1.0); ControlObject::set(ConfigKey(m_sGroup2, "play"), 1.0); - EXPECT_TRUE(isExplicitMaster(m_sGroup1)); + EXPECT_TRUE(isExplicitLeader(m_sGroup1)); EXPECT_TRUE(isFollower(m_sGroup2)); ProcessBuffer(); @@ -2438,7 +2440,7 @@ TEST_F(EngineSyncTest, MasterUserTweakPreservedInMasterChange) { EXPECT_DOUBLE_EQ(kDivisibleBpm, ControlObject::getControl(ConfigKey(m_sGroup2, "bpm"))->get()); - // Apply user tweak offset to master -- to test the bug we found, we need + // Apply user tweak offset to leader -- to test the bug we found, we need // to apply it indirectly. ControlObject::set(ConfigKey(m_sGroup1, "rate_temp_up"), 1); for (int i = 0; i < 5; ++i) { @@ -2449,11 +2451,11 @@ TEST_F(EngineSyncTest, MasterUserTweakPreservedInMasterChange) { } ControlObject::set(ConfigKey(m_sGroup1, "rate_temp_up"), 0); - // Switch master - ControlObject::getControl(ConfigKey(m_sGroup2, "sync_master"))->set(1); + // Switch leader + ControlObject::getControl(ConfigKey(m_sGroup2, "sync_leader"))->set(1); ProcessBuffer(); EXPECT_TRUE(isFollower(m_sGroup1)); - EXPECT_TRUE(isExplicitMaster(m_sGroup2)); + EXPECT_TRUE(isExplicitLeader(m_sGroup2)); for (int i = 0; i < 10; ++i) { ProcessBuffer(); @@ -2463,7 +2465,7 @@ TEST_F(EngineSyncTest, MasterUserTweakPreservedInMasterChange) { } } -TEST_F(EngineSyncTest, MasterBpmNeverZero) { +TEST_F(EngineSyncTest, LeaderBpmNeverZero) { mixxx::BeatsPointer pBeats1 = BeatFactory::makeBeatGrid( m_pTrack1->getSampleRate(), mixxx::Bpm(128), mixxx::audio::kStartFramePos); m_pTrack1->trySetBeats(pBeats1); @@ -2738,7 +2740,7 @@ TEST_F(EngineSyncTest, ChangeBeatGrid) { ProcessBuffer(); - EXPECT_TRUE(isSoftMaster(m_sGroup1)); + EXPECT_TRUE(isSoftLeader(m_sGroup1)); EXPECT_DOUBLE_EQ(130.0, ControlObject::get(ConfigKey(m_sGroup1, "bpm"))); EXPECT_DOUBLE_EQ(130.0, ControlObject::get(ConfigKey(m_sInternalClockGroup, "bpm"))); @@ -2749,7 +2751,7 @@ TEST_F(EngineSyncTest, ChangeBeatGrid) { ProcessBuffer(); // expect no change in Deck 1 - EXPECT_TRUE(isSoftMaster(m_sGroup1)); + EXPECT_TRUE(isSoftLeader(m_sGroup1)); EXPECT_TRUE(isFollower(m_sGroup2)); EXPECT_DOUBLE_EQ(130.0, ControlObject::get(ConfigKey(m_sGroup1, "bpm"))); EXPECT_DOUBLE_EQ(0, ControlObject::get(ConfigKey(m_sGroup2, "bpm"))); @@ -2759,8 +2761,8 @@ TEST_F(EngineSyncTest, ChangeBeatGrid) { ControlObject::set(ConfigKey(m_sGroup1, "play"), 0.0); ProcessBuffer(); - // Group1 remains master because it is the only one with a tempo. - EXPECT_TRUE(isSoftMaster(m_sGroup1)); + // Group1 remains leader because it is the only one with a tempo. + EXPECT_TRUE(isSoftLeader(m_sGroup1)); EXPECT_TRUE(isFollower(m_sGroup2)); // Load a new beatgrid during playing, this happens when the analyser is finished. @@ -2771,9 +2773,9 @@ TEST_F(EngineSyncTest, ChangeBeatGrid) { ProcessBuffer(); // Since deck 1 is not playing, deck 2 doesn't change its speed to match theirs. Deck 2 - // should be master now, and playing at our own rate. The other deck should have + // should be leader now, and playing at our own rate. The other deck should have // changed rate to match us. - EXPECT_TRUE(isSoftMaster(m_sGroup2)); + EXPECT_TRUE(isSoftLeader(m_sGroup2)); EXPECT_TRUE(isFollower(m_sGroup1)); EXPECT_TRUE(isFollower(m_sInternalClockGroup)); EXPECT_DOUBLE_EQ(140.0, ControlObject::get(ConfigKey(m_sGroup1, "bpm"))); @@ -2786,7 +2788,7 @@ TEST_F(EngineSyncTest, ChangeBeatGrid) { EXPECT_TRUE(isFollower(m_sInternalClockGroup)); EXPECT_TRUE(isFollower(m_sGroup1)); - EXPECT_TRUE(isSoftMaster(m_sGroup2)); + EXPECT_TRUE(isSoftLeader(m_sGroup2)); // Load a new beatgrid again, this happens when the user adjusts the beatgrid mixxx::BeatsPointer pBeats2n = BeatFactory::makeBeatGrid( @@ -2795,7 +2797,7 @@ TEST_F(EngineSyncTest, ChangeBeatGrid) { ProcessBuffer(); - // We expect that the second deck is still playing at unity -- it was the master + // We expect that the second deck is still playing at unity -- it was the leader // and it should not change speed just because it reloaded and the bpm changed. EXPECT_DOUBLE_EQ(75.0, ControlObject::get(ConfigKey(m_sGroup1, "bpm"))); // Expect to sync on half beats @@ -2824,8 +2826,10 @@ TEST_F(EngineSyncTest, BeatMapQuantizePlay) { ControlObject::set(ConfigKey(m_sGroup1, "quantize"), 1.0); ControlObject::set(ConfigKey(m_sGroup2, "quantize"), 1.0); - ControlObject::getControl(ConfigKey(m_sGroup1, "sync_mode"))->set(SYNC_MASTER_EXPLICIT); - ControlObject::getControl(ConfigKey(m_sGroup2, "sync_mode"))->set(SYNC_FOLLOWER); + ControlObject::getControl(ConfigKey(m_sGroup1, "sync_mode")) + ->set(static_cast(SyncMode::LeaderExplicit)); + ControlObject::getControl(ConfigKey(m_sGroup2, "sync_mode")) + ->set(static_cast(SyncMode::Follower)); ControlObject::getControl(ConfigKey(m_sGroup1, "play"))->set(1.0); @@ -2859,17 +2863,17 @@ TEST_F(EngineSyncTest, BpmAdjustFactor) { ControlObject::set(ConfigKey(m_sGroup2, "sync_enabled"), 1.0); ProcessBuffer(); - // group 2 should be synced to the first playing deck and becomes master + // group 2 should be synced to the first playing deck and becomes leader EXPECT_DOUBLE_EQ(40.0, ControlObject::get(ConfigKey(m_sGroup1, "bpm"))); EXPECT_DOUBLE_EQ(80.0, ControlObject::get(ConfigKey(m_sGroup2, "bpm"))); - EXPECT_TRUE(isSoftMaster(m_sGroup2)); + EXPECT_TRUE(isSoftLeader(m_sGroup2)); assertSyncOff(m_sGroup1); ControlObject::set(ConfigKey(m_sGroup2, "play"), 1.0); ProcessBuffer(); - EXPECT_TRUE(isSoftMaster(m_sGroup2)); + EXPECT_TRUE(isSoftLeader(m_sGroup2)); // Pretend a changing beatgrid - static_cast(m_pEngineSync->getMasterSyncable())->setLocalBpm(152); + static_cast(m_pEngineSync->getLeaderSyncable())->setLocalBpm(152); ProcessBuffer(); ControlObject::set(ConfigKey(m_sGroup1, "sync_enabled"), 1.0); @@ -2880,11 +2884,11 @@ TEST_F(EngineSyncTest, BpmAdjustFactor) { EXPECT_DOUBLE_EQ(40.0, ControlObject::get(ConfigKey(m_sGroup1, "bpm"))); EXPECT_DOUBLE_EQ(80.0, ControlObject::get(ConfigKey(m_sGroup2, "bpm"))); EXPECT_TRUE(isFollower(m_sGroup1)); - EXPECT_TRUE(isSoftMaster(m_sGroup2)); + EXPECT_TRUE(isSoftLeader(m_sGroup2)); EXPECT_TRUE(isFollower(m_sInternalClockGroup)); } -TEST_F(EngineSyncTest, ImplicitMasterToInternalClock) { +TEST_F(EngineSyncTest, ImplicitLeaderToInternalClock) { m_pMixerDeck1->loadFakeTrack(false, 100.0); m_pMixerDeck2->loadFakeTrack(false, 125.0); ProcessBuffer(); @@ -2902,26 +2906,26 @@ TEST_F(EngineSyncTest, ImplicitMasterToInternalClock) { ControlObject::set(ConfigKey(m_sGroup2, "sync_enabled"), 1.0); ProcessBuffer(); - // group 2 should be synced to the first playing deck and becomes master + // group 2 should be synced to the first playing deck and becomes leader EXPECT_DOUBLE_EQ(125.0, ControlObject::get(ConfigKey(m_sGroup1, "bpm"))); EXPECT_DOUBLE_EQ(125.0, ControlObject::get(ConfigKey(m_sGroup2, "bpm"))); - ASSERT_FALSE(isSoftMaster(m_sGroup1)); - ASSERT_TRUE(isSoftMaster(m_sGroup2)); - ASSERT_FALSE(isSoftMaster(m_sInternalClockGroup)); + ASSERT_FALSE(isSoftLeader(m_sGroup1)); + ASSERT_TRUE(isSoftLeader(m_sGroup2)); + ASSERT_FALSE(isSoftLeader(m_sInternalClockGroup)); ProcessBuffer(); // Drop Track, no change ControlObject::set(ConfigKey(m_sGroup1, "volume"), 1.0); - ASSERT_FALSE(isSoftMaster(m_sGroup1)); - ASSERT_TRUE(isSoftMaster(m_sGroup2)); - ASSERT_FALSE(isSoftMaster(m_sInternalClockGroup)); + ASSERT_FALSE(isSoftLeader(m_sGroup1)); + ASSERT_TRUE(isSoftLeader(m_sGroup2)); + ASSERT_FALSE(isSoftLeader(m_sInternalClockGroup)); - // Other track stops, master switches to deck 1 + // Other track stops, leader switches to deck 1 ControlObject::set(ConfigKey(m_sGroup2, "volume"), 0.0); ProcessBuffer(); ProcessBuffer(); - ASSERT_TRUE(isSoftMaster(m_sGroup1)); - ASSERT_FALSE(isSoftMaster(m_sGroup2)); - ASSERT_FALSE(isSoftMaster(m_sInternalClockGroup)); + ASSERT_TRUE(isSoftLeader(m_sGroup1)); + ASSERT_FALSE(isSoftLeader(m_sGroup2)); + ASSERT_FALSE(isSoftLeader(m_sInternalClockGroup)); } diff --git a/src/test/synccontroltest.cpp b/src/test/synccontroltest.cpp index 9e9e8a159bf..59a62d88a29 100644 --- a/src/test/synccontroltest.cpp +++ b/src/test/synccontroltest.cpp @@ -1,7 +1,7 @@ -// Tests for Master Sync. +// Tests for Sync Lock. // There are no tests for actual deck playback, since I don't know how to mock that out yet. // The following manual tests should probably be performed: -// * Quantize mode nudges tracks in sync, whether internal or deck master. +// * Quantize mode nudges tracks in sync, whether internal or deck leader. // * Flinging tracks with the waveform should work. // * vinyl??