From 9e857968c4fbeee2b114f16fff3d1064752af15b Mon Sep 17 00:00:00 2001 From: Owen Williams Date: Fri, 28 May 2021 16:34:16 -0400 Subject: [PATCH] Rename Sync instances of "master" to "leader" Also add an alias from the sync_master CO to sync_leader --- .../Hercules DJ Control MP3 e2-scripts.js | 2 +- .../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/skins/LateNight/decks/rate_controls.xml | 6 +- src/controllers/controlpickermenu.cpp | 9 +- src/engine/controls/bpmcontrol.cpp | 4 +- src/engine/controls/bpmcontrol.h | 4 +- src/engine/controls/ratecontrol.cpp | 6 +- src/engine/controls/ratecontrol.h | 2 +- src/engine/enginebuffer.cpp | 4 +- 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 | 232 +++--- src/engine/sync/enginesync.h | 72 +- src/engine/sync/internalclock.cpp | 58 +- src/engine/sync/internalclock.h | 18 +- src/engine/sync/syncable.h | 62 +- src/engine/sync/synccontrol.cpp | 120 +-- src/engine/sync/synccontrol.h | 24 +- src/mixer/basetrackplayer.cpp | 2 +- src/skin/legacy/tooltips.cpp | 6 +- src/test/enginesynctest.cpp | 694 +++++++++--------- src/test/synccontroltest.cpp | 2 +- 28 files changed, 695 insertions(+), 688 deletions(-) diff --git a/res/controllers/Hercules DJ Control MP3 e2-scripts.js b/res/controllers/Hercules DJ Control MP3 e2-scripts.js index a019e21604d..cd811906bb7 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 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 1b87f171e74..90b0d317c61 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 aeb87ae3216..75e456d4a07 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/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..1cc4efc161d 100644 --- a/src/controllers/controlpickermenu.cpp +++ b/src/controllers/controlpickermenu.cpp @@ -224,8 +224,11 @@ 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]", + "sync_leader", + tr("Internal Sync Leader"), + tr("Toggle Internal Sync Leader"), + syncMenu); addControl("[InternalClock]", "bpm", tr("Internal Master BPM"), tr("Internal Master BPM"), syncMenu); addControl("[InternalClock]", "bpm_up", tr("Internal Master BPM +1"), @@ -239,7 +242,7 @@ ControlPickerMenu::ControlPickerMenu(QWidget* pParent) addControl("[InternalClock]", "bpm_down_small", tr("Internal Master BPM -0.1"), tr("Decrease internal master BPM by 0.1"), syncMenu); syncMenu->addSeparator(); - addDeckAndSamplerControl("sync_master", tr("Sync Master"), tr("Toggle sync master"), syncMenu); + addDeckAndSamplerControl("sync_leader", tr("Sync Leader"), tr("Toggle sync master"), syncMenu); addDeckAndSamplerControl("sync_mode", tr("Sync Mode"), tr("Sync mode 3-state toggle (OFF, FOLLOWER, MASTER)"), syncMenu); diff --git a/src/engine/controls/bpmcontrol.cpp b/src/engine/controls/bpmcontrol.cpp index d72f6ff7921..6579826992a 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() == SYNC_LEADER_EXPLICIT) { return false; } EngineBuffer* pOtherEngineBuffer = pickSyncTarget(); @@ -1056,7 +1056,7 @@ void BpmControl::slotBeatsTranslateMatchAlignment(double v) { const mixxx::BeatsPointer pBeats = pTrack->getBeats(); if (pBeats && (pBeats->getCapabilities() & mixxx::Beats::BEATSCAP_TRANSLATE)) { // 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 offset = getPhaseOffset(getSampleOfTrack().current); diff --git a/src/engine/controls/bpmcontrol.h b/src/engine/controls/bpmcontrol.h index 7e5e3446b26..540f93e4d2c 100644 --- a/src/engine/controls/bpmcontrol.h +++ b/src/engine/controls/bpmcontrol.h @@ -27,7 +27,7 @@ class BpmControl : public EngineControl { double getBpm() const; double getLocalBpm() const { return m_pLocalBpm ? m_pLocalBpm->get() : 0.0; } - // 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 @@ -173,5 +173,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 58fcfee17dd..1ad1419ff22 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 80065ba2b25..09b5aad2b0e 100644 --- a/src/engine/enginebuffer.cpp +++ b/src/engine/enginebuffer.cpp @@ -1158,7 +1158,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); @@ -1300,7 +1300,7 @@ void EngineBuffer::postProcess(const int iBufferSize) { m_pSyncControl->setLocalBpm(localBpm); 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. diff --git a/src/engine/enginebuffer.h b/src/engine/enginebuffer.h index bc2695a3d6f..61090a22b93 100644 --- a/src/engine/enginebuffer.h +++ b/src/engine/enginebuffer.h @@ -256,7 +256,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 202fe0b1341..8b63b51360d 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 7be0f0fe283..66b9f80032a 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,14 +41,14 @@ 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 SYNC_LEADER_EXPLICIT: + case SYNC_LEADER_SOFT: { 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); @@ -57,12 +57,12 @@ void EngineSync::requestSyncMode(Syncable* pSyncable, SyncMode mode) { } case SYNC_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, SYNC_LEADER_SOFT); } break; } @@ -82,26 +82,26 @@ 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 != SYNC_LEADER_EXPLICIT) { 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 +120,47 @@ 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); } -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 == SYNC_LEADER_SOFT || leaderType == SYNC_LEADER_EXPLICIT) { + 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(SYNC_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,9 +174,9 @@ 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. @@ -185,27 +185,27 @@ void EngineSync::deactivateSync(Syncable* pSyncable) { bool bSyncDeckExists = syncDeckExists(); if (pSyncable != m_pInternalClock && !bSyncDeckExists) { // Deactivate the internal clock if there are no more sync decks left. - m_pMasterSyncable = nullptr; + m_pLeaderSyncable = nullptr; m_pInternalClock->setSyncMode(SYNC_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, SYNC_LEADER_SOFT); } } } -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() == SYNC_LEADER_EXPLICIT && + m_pLeaderSyncable->getBaseBpm() != 0.0) { + return m_pLeaderSyncable; } // First preference: some other sync deck that is not playing. @@ -252,10 +252,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 +300,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 +357,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, SYNC_LEADER_SOFT); + 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 +387,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 +397,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 +408,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 +433,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 +447,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,7 +467,7 @@ 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(); @@ -531,8 +531,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 +553,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 +601,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 +654,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..9d759a74315 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,32 +56,32 @@ 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); @@ -89,50 +89,50 @@ class EngineSync : public SyncableListener { /// This utility method returns true if it finds a deck not in SYNC_NONE mode. 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..7908ab290e8 100644 --- a/src/engine/sync/internalclock.cpp +++ b/src/engine/sync/internalclock.cpp @@ -24,7 +24,7 @@ InternalClock::InternalClock(const QString& group, SyncableListener* pEngineSync 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(SyncModeToLeaderLight(mode)); } void InternalClock::notifyUniquePlaying() { @@ -68,27 +70,27 @@ 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 == SYNC_LEADER_EXPLICIT) { + // Already leader. return; } - if (mode == SYNC_MASTER_SOFT) { - // user request: make master explicit - m_mode = SYNC_MASTER_EXPLICIT; + if (mode == SYNC_LEADER_SOFT) { + // user request: make leader explicit + m_mode = SYNC_LEADER_EXPLICIT; return; } if (mode == SYNC_NONE) { m_dBaseBpm = m_dOldBpm; } - m_pEngineSync->requestSyncMode(this, SYNC_MASTER_EXPLICIT); + m_pEngineSync->requestSyncMode(this, SYNC_LEADER_EXPLICIT); } else { - // Turning off master goes back to follower mode. + // Turning off leader goes back to follower mode. if (mode == SYNC_FOLLOWER) { - // Already not master. + // Already not leader. return; } m_pEngineSync->requestSyncMode(this, SYNC_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..53670cfc5b7 100644 --- a/src/engine/sync/syncable.h +++ b/src/engine/sync/syncable.h @@ -8,13 +8,13 @@ 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 + // SYNC_LEADER_SOFT is a leader that Mixxx has chosen automatically. + // depending on how decks stop and start, it may reassign soft leader at will. + SYNC_LEADER_SOFT = 2, + // SYNC_LEADER_EXPLICIT represents an explicit request that the synacable be + // leader. Mixxx will only remove a SYNC_LEADER_SOFT if the track is stopped or // ejected. - SYNC_MASTER_EXPLICIT = 3, + SYNC_LEADER_EXPLICIT = 3, SYNC_NUM_MODES }; @@ -35,36 +35,36 @@ inline bool isFollower(SyncMode mode) { return (mode == SYNC_FOLLOWER); } -inline bool isMaster(SyncMode mode) { - return (mode == SYNC_MASTER_SOFT || mode == SYNC_MASTER_EXPLICIT); +inline bool isLeader(SyncMode mode) { + return (mode == SYNC_LEADER_SOFT || mode == SYNC_LEADER_EXPLICIT); } -enum SyncMasterLight { - MASTER_INVALID = -1, - MASTER_OFF = 0, - MASTER_SOFT = 1, - MASTER_EXPLICIT = 2, +enum SyncLeaderLight { + LEADER_INVALID = -1, + LEADER_OFF = 0, + LEADER_SOFT = 1, + LEADER_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; + return LEADER_OFF; + case SYNC_LEADER_SOFT: + return LEADER_SOFT; + case SYNC_LEADER_EXPLICIT: + return LEADER_EXPLICIT; break; case SYNC_NUM_MODES: break; } - return MASTER_INVALID; + return LEADER_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,25 +103,25 @@ 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. // Must never result in a call to @@ -141,7 +141,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 +162,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 604a55db176..8268ead97a5 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, @@ -52,12 +52,14 @@ SyncControl::SyncControl(const QString& group, 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"))); @@ -127,7 +129,7 @@ void SyncControl::setSyncMode(SyncMode mode) { // requires. Bypass confirmation by using setAndConfirm. m_pSyncMode->setAndConfirm(mode); m_pSyncEnabled->setAndConfirm(mode != SYNC_NONE); - m_pSyncMasterEnabled->setAndConfirm(SyncModeToMasterLight(mode)); + m_pSyncLeaderEnabled->setAndConfirm(SyncModeToLeaderLight(mode)); if (mode == SYNC_FOLLOWER) { if (m_pVCEnabled && m_pVCEnabled->toBool()) { // If follower mode is enabled, disable vinyl control. @@ -143,7 +145,7 @@ void SyncControl::setSyncMode(SyncMode mode) { m_pPassthroughEnabled->set(0.0); } if (mode == SYNC_NONE) { - m_masterBpmAdjustFactor = kBpmUnity; + 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,9 +221,9 @@ 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()) { @@ -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,20 +308,20 @@ 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) { + if (isLeader(getSyncMode()) && fractionalPlaypos >= 1.0) { m_pChannel->getEngineBuffer()->requestSyncMode(SYNC_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. + // be leader. m_pChannel->getEngineBuffer()->requestSyncMode(SYNC_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(); } @@ -401,9 +403,9 @@ void SyncControl::slotSyncModeChangeRequest(double state) { } } -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,14 +413,14 @@ 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(SYNC_LEADER_EXPLICIT); } 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 SYNC_LEADER_EXPLICIT: + m_pChannel->getEngineBuffer()->requestSyncMode(SYNC_LEADER_SOFT); break; - case SYNC_MASTER_SOFT: + case SYNC_LEADER_SOFT: m_pChannel->getEngineBuffer()->requestSyncMode(SYNC_FOLLOWER); break; default: @@ -456,16 +458,16 @@ void SyncControl::setLocalBpm(double local_bpm) { 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 7b44ced9da0..51dfb77f7c0 100644 --- a/src/mixer/basetrackplayer.cpp +++ b/src/mixer/basetrackplayer.cpp @@ -481,7 +481,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..420f886e241 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,7 +549,7 @@ void Tooltips::addStandardTooltips() { // Awesome-Sync (TM) add("sync_enabled") - << tr("Enable Master Sync") + << tr("Enable Sync Lock") << tr("Tap to sync the tempo to other playing tracks or the master clock.") << 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 " @@ -562,7 +562,7 @@ 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") + add("sync_leader") << tr("Enable Sync Clock Master") << tr("When enabled, this device will serve as the master clock for all other decks."); diff --git a/src/test/enginesynctest.cpp b/src/test/enginesynctest.cpp index fc51115364a..99e5bb7935a 100644 --- a/src/test/enginesynctest.cpp +++ b/src/test/enginesynctest.cpp @@ -20,33 +20,33 @@ 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, SYNC_LEADER_EXPLICIT); } - bool isSoftMaster(const QString& group) { - return isMaster(group, SYNC_MASTER_SOFT); + bool isSoftLeader(const QString& group) { + return isLeader(group, SYNC_LEADER_SOFT); } 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")) @@ -59,11 +59,11 @@ class EngineSyncTest : public MockedEngineBackendTest { 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,7 +73,7 @@ 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, @@ -83,105 +83,105 @@ class EngineSyncTest : public MockedEngineBackendTest { 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 == SYNC_LEADER_SOFT && 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 == SYNC_LEADER_EXPLICIT && 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; + 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 SYNC_LEADER_SOFT: { + 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 SYNC_LEADER_EXPLICIT: { + 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->slotSet(SYNC_MASTER_EXPLICIT); + pButtonLeaderSync1->slotSet(SYNC_LEADER_EXPLICIT); 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, SYNC_leader_EXPLICIT 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(SYNC_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(SYNC_LEADER_EXPLICIT); 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(SYNC_LEADER_EXPLICIT); 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->slotSet(SYNC_FOLLOWER); + pButtonLeaderSync1->slotSet(SYNC_FOLLOWER); ProcessBuffer(); EXPECT_TRUE(isFollower(m_sInternalClockGroup)); @@ -241,28 +241,28 @@ 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(), 120, 0.0); m_pTrack1->trySetBeats(pBeats1); mixxx::BeatsPointer pBeats2 = BeatFactory::makeBeatGrid(m_pTrack2->getSampleRate(), 124, 0.0); 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->slotSet(SYNC_MASTER_EXPLICIT); + pButtonLeaderSync1->slotSet(SYNC_LEADER_EXPLICIT); 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. @@ -270,12 +270,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(), 120, 0.0); m_pTrack1->trySetBeats(pBeats1); mixxx::BeatsPointer pBeats2 = BeatFactory::makeBeatGrid(m_pTrack2->getSampleRate(), 124, 0.0); @@ -283,15 +283,15 @@ TEST_F(EngineSyncTest, SetMasterWhilePlaying) { mixxx::BeatsPointer pBeats3 = BeatFactory::makeBeatGrid(m_pTrack3->getSampleRate(), 128, 0.0); m_pTrack3->trySetBeats(pBeats3); - auto pButtonMasterSync1 = + auto pButtonLeaderSync1 = std::make_unique(m_sGroup1, "sync_mode"); - pButtonMasterSync1->set(SYNC_MASTER_EXPLICIT); - auto pButtonMasterSync2 = + pButtonLeaderSync1->set(SYNC_LEADER_EXPLICIT); + auto pButtonLeaderSync2 = std::make_unique(m_sGroup2, "sync_mode"); - pButtonMasterSync2->slotSet(SYNC_FOLLOWER); - auto pButtonMasterSync3 = + pButtonLeaderSync2->slotSet(SYNC_FOLLOWER); + auto pButtonLeaderSync3 = std::make_unique(m_sGroup3, "sync_mode"); - pButtonMasterSync3->slotSet(SYNC_FOLLOWER); + pButtonLeaderSync3->slotSet(SYNC_FOLLOWER); ControlObject::getControl(ConfigKey(m_sGroup1, "play"))->set(1.0); ControlObject::getControl(ConfigKey(m_sGroup2, "play"))->set(1.0); @@ -299,32 +299,32 @@ TEST_F(EngineSyncTest, SetMasterWhilePlaying) { ProcessBuffer(); - pButtonMasterSync3->slotSet(SYNC_MASTER_EXPLICIT); + pButtonLeaderSync3->slotSet(SYNC_LEADER_EXPLICIT); 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(), 80, 0.0); m_pTrack1->trySetBeats(pBeats1); - auto pButtonMasterSync1 = + auto pButtonLeaderSync1 = std::make_unique(m_sGroup1, "sync_mode"); - pButtonMasterSync1->slotSet(SYNC_FOLLOWER); + pButtonLeaderSync1->slotSet(SYNC_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->slotSet(1.0); +TEST_F(EngineSyncTest, DisableInternalLeaderWhilePlaying) { + auto pButtonLeaderSync = std::make_unique( + m_sInternalClockGroup, "sync_leader"); + pButtonLeaderSync->slotSet(1.0); auto pButtonSyncMode1 = std::make_unique(m_sGroup1, "sync_mode"); pButtonSyncMode1->slotSet(SYNC_FOLLOWER); @@ -332,8 +332,8 @@ TEST_F(EngineSyncTest, DisableInternalMasterWhilePlaying) { std::make_unique(m_sGroup2, "sync_mode"); pButtonSyncMode2->slotSet(SYNC_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(m_pTrack1->getSampleRate(), 80, 0.0); @@ -344,17 +344,17 @@ TEST_F(EngineSyncTest, DisableInternalMasterWhilePlaying) { ControlObject::getControl(ConfigKey(m_sGroup2, "play"))->set(1.0); ProcessBuffer(); - // Now unset Internal master. - pButtonMasterSync->slotSet(0.0); + // Now unset Internal leader. + pButtonLeaderSync->slotSet(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(), 130, 0.0); m_pTrack1->trySetBeats(pBeats1); auto pButtonSyncMode1 = @@ -363,48 +363,48 @@ TEST_F(EngineSyncTest, DisableSyncOnMaster) { mixxx::BeatsPointer pBeats2 = BeatFactory::makeBeatGrid(m_pTrack2->getSampleRate(), 130, 0.0); m_pTrack2->trySetBeats(pBeats2); - // Set deck two to explicit master. - auto pButtonSyncMaster2 = - std::make_unique(m_sGroup2, "sync_master"); - pButtonSyncMaster2->slotSet(1.0); + // Set deck two to explicit leader. + auto pButtonSyncLeader2 = + std::make_unique(m_sGroup2, "sync_leader"); + pButtonSyncLeader2->slotSet(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->slotSet(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->slotSet(1); + pLeaderSyncSlider->set(100.0); + pButtonLeaderSyncInternal->slotSet(1); // Set the file bpm of channel 1 to 80 bpm. mixxx::BeatsPointer pBeats1 = BeatFactory::makeBeatGrid(m_pTrack1->getSampleRate(), 80, 0.0); m_pTrack1->trySetBeats(pBeats1); - auto pButtonMasterSync1 = + auto pButtonLeaderSync1 = std::make_unique(m_sGroup1, "sync_mode"); - pButtonMasterSync1->slotSet(SYNC_FOLLOWER); + pButtonLeaderSync1->slotSet(SYNC_FOLLOWER); ProcessBuffer(); EXPECT_DOUBLE_EQ(getRateSliderValue(1.25), @@ -415,7 +415,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(), 80, 0.0); m_pTrack1->trySetBeats(pBeats1); @@ -442,9 +442,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"); @@ -466,8 +466,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"))); @@ -475,8 +475,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)); @@ -488,17 +488,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. @@ -506,20 +506,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(m_pTrack1->getSampleRate(), 160, 0.0); @@ -531,12 +531,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->slotSet(1.0); + // Set channel 1 to be explicit leader. + pButtonSyncLeader1->slotSet(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->slotSet(1); @@ -544,49 +544,49 @@ TEST_F(EngineSyncTest, SetExplicitMasterByLights) { EXPECT_TRUE(isFollower(m_sGroup2)); - // Now set channel 2 to be master. - pButtonSyncMaster2->slotSet(1); + // Now set channel 2 to be leader. + pButtonSyncLeader2->slotSet(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->slotSet(1); + pButtonSyncLeader1->slotSet(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->slotSet(0); + // Now set channel 1 to not-leader. The system will choose deck 2 as the next best + // option for soft leader + pButtonSyncLeader1->slotSet(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->slotSet(1); + pButtonSyncLeader1->slotSet(1); // Set channel 2 to be follower. pButtonSyncEnabled2->slotSet(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->slotSet(0); + pButtonSyncLeader1->slotSet(0); EXPECT_TRUE(isFollower(m_sGroup1)); EXPECT_TRUE(isFollower(m_sGroup2)); @@ -594,12 +594,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(SYNC_LEADER_EXPLICIT); + auto pButtonLeaderSync2 = std::make_unique(m_sGroup2, "sync_mode"); - pButtonMasterSync2->set(SYNC_FOLLOWER); + pButtonLeaderSync2->set(SYNC_FOLLOWER); ProcessBuffer(); // Set the file bpm of channel 1 to 160bpm. @@ -617,7 +617,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"))); @@ -635,12 +635,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->slotSet(SYNC_MASTER_EXPLICIT); - auto pButtonMasterSync2 = + pButtonLeaderSync1->slotSet(SYNC_LEADER_EXPLICIT); + auto pButtonLeaderSync2 = std::make_unique(m_sGroup2, "sync_mode"); - pButtonMasterSync2->slotSet(SYNC_FOLLOWER); + pButtonLeaderSync2->slotSet(SYNC_FOLLOWER); ProcessBuffer(); // Set the file bpm of channel 1 to 160bpm. @@ -661,7 +661,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"))); } @@ -679,19 +679,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(SYNC_LEADER_EXPLICIT); 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(SYNC_FOLLOWER); ProcessBuffer(); // Follower should immediately set its slider. @@ -704,13 +704,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(SYNC_LEADER_EXPLICIT); + auto pButtonLeaderSync2 = std::make_unique(m_sGroup2, "sync_mode"); - pButtonMasterSync2->set(SYNC_FOLLOWER); + pButtonLeaderSync2->set(SYNC_FOLLOWER); ProcessBuffer(); // Set the file bpm of channel 1 to 160bpm. @@ -744,18 +744,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(SYNC_FOLLOWER); + auto pButtonLeaderSync2 = std::make_unique(m_sGroup2, "sync_mode"); - pButtonMasterSync2->set(SYNC_FOLLOWER); + pButtonLeaderSync2->set(SYNC_FOLLOWER); ProcessBuffer(); - EXPECT_TRUE(isExplicitMaster(m_sInternalClockGroup)); + EXPECT_TRUE(isExplicitLeader(m_sInternalClockGroup)); EXPECT_TRUE(isFollower(m_sGroup1)); EXPECT_TRUE(isFollower(m_sGroup2)); @@ -772,9 +772,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()); @@ -793,7 +793,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(); @@ -810,22 +810,22 @@ 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(), 120, 0.0); m_pTrack1->trySetBeats(pBeats1); mixxx::BeatsPointer pBeats2 = BeatFactory::makeBeatGrid(m_pTrack2->getSampleRate(), 128, 0.0); m_pTrack2->trySetBeats(pBeats2); - auto pButtonMasterSync1 = + auto pButtonLeaderSync1 = std::make_unique(m_sGroup1, "sync_mode"); - pButtonMasterSync1->slotSet(SYNC_MASTER_EXPLICIT); - auto pButtonMasterSync2 = + pButtonLeaderSync1->slotSet(SYNC_LEADER_EXPLICIT); + auto pButtonLeaderSync2 = std::make_unique(m_sGroup2, "sync_mode"); - pButtonMasterSync2->slotSet(SYNC_FOLLOWER); + pButtonLeaderSync2->slotSet(SYNC_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"); @@ -848,9 +848,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(); @@ -868,8 +868,8 @@ TEST_F(EngineSyncTest, EnableOneDeckInitsMaster) { m_pEngineSync->requestSyncMode( m_pEngineSync->getSyncableForGroup(m_sGroup1), SYNC_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. @@ -892,9 +892,9 @@ TEST_F(EngineSyncTest, EnableOneDeckInitsMaster) { m_pEngineSync->requestSyncMode( m_pEngineSync->getSyncableForGroup(m_sGroup2), SYNC_FOLLOWER); - // Deck 1 is still soft master. + // 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( @@ -928,8 +928,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(), 130, 0.0); m_pTrack1->trySetBeats(pBeats1); @@ -943,8 +943,8 @@ TEST_F(EngineSyncTest, EnableOneDeckInitializesMaster) { m_pEngineSync->requestSyncMode( m_pEngineSync->getSyncableForGroup(m_sGroup1), SYNC_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, @@ -961,7 +961,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); @@ -971,24 +971,24 @@ TEST_F(EngineSyncTest, LoadTrackInitializesMaster) { std::make_unique(m_sGroup1, "sync_enabled"); pButtonSyncEnabled1->slotSet(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 @@ -1000,13 +1000,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)); @@ -1020,9 +1020,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)); @@ -1035,13 +1035,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. @@ -1117,7 +1117,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"); @@ -1130,8 +1130,8 @@ TEST_F(EngineSyncTest, EnableOneDeckSliderUpdates) { pButtonSyncEnabled1->slotSet(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, @@ -1165,9 +1165,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); @@ -1182,17 +1182,17 @@ 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(NULL, m_pEngineSync->getLeader()); + EXPECT_EQ(NULL, m_pEngineSync->getLeaderSyncable()); EXPECT_EQ(SYNC_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"))); @@ -1207,17 +1207,17 @@ 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(NULL, m_pEngineSync->getLeader()); + EXPECT_EQ(NULL, m_pEngineSync->getLeaderSyncable()); EXPECT_EQ(SYNC_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"))); } @@ -1248,8 +1248,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( @@ -1263,7 +1263,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( @@ -1277,7 +1277,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( @@ -1292,7 +1292,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( @@ -1313,7 +1313,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); @@ -1337,7 +1337,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); @@ -1346,11 +1346,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(), 100, 0.0); m_pTrack1->trySetBeats(pBeats1); auto pButtonSyncEnabled1 = @@ -1365,16 +1365,16 @@ 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(), 160, 0.0); 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(m_pTrack2->getSampleRate(), 140, 0.0); @@ -1383,12 +1383,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->slotSet(SYNC_MASTER_EXPLICIT); + pButtonLeaderSync1->slotSet(SYNC_LEADER_EXPLICIT); mixxx::BeatsPointer pBeats1 = BeatFactory::makeBeatGrid(m_pTrack1->getSampleRate(), 160, 0.0); m_pTrack1->trySetBeats(pBeats1); ProcessBuffer(); @@ -1425,10 +1425,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(SYNC_LEADER_EXPLICIT); ControlObject::getControl(ConfigKey(m_sGroup1, "rate")) ->set(getRateSliderValue(1.4)); @@ -1454,7 +1454,7 @@ TEST_F(EngineSyncTest, DISABLED_BeatDistanceBeforeStart) { m_pTrack1->trySetBeats(pBeats1); ControlObject::set(ConfigKey(m_sGroup1, "playposition"), -.05); ControlObject::getControl(ConfigKey(m_sGroup1, "sync_mode")) - ->set(SYNC_MASTER_SOFT); + ->set(SYNC_LEADER_SOFT); ControlObject::getControl(ConfigKey(m_sGroup1, "play"))->set(1.0); ProcessBuffer(); EXPECT_NEAR( @@ -1464,14 +1464,14 @@ TEST_F(EngineSyncTest, DISABLED_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(), 128, 0.0); m_pTrack1->trySetBeats(pBeats1); mixxx::BeatsPointer pBeats2 = BeatFactory::makeBeatGrid(m_pTrack2->getSampleRate(), 160, 0.0); 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); ControlObject::getControl(ConfigKey(m_sGroup1, "sync_mode")) @@ -1512,7 +1512,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(), 128, 0.0); m_pTrack1->trySetBeats(pBeats1); @@ -1522,7 +1522,7 @@ 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); ControlObject::getControl(ConfigKey(m_sGroup1, "sync_mode")) @@ -1565,7 +1565,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(), 128, 0.0); m_pTrack1->trySetBeats(pBeats1); @@ -1574,7 +1574,7 @@ 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); ControlObject::getControl(ConfigKey(m_sGroup1, "sync_mode")) @@ -1616,7 +1616,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 @@ -1640,11 +1640,11 @@ 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); - // engage second Sync-master + // engage second Sync-leader ControlObject::getControl(ConfigKey(m_sGroup2, "sync_mode")) ->set(SYNC_FOLLOWER); @@ -1670,7 +1670,7 @@ TEST_F(EngineSyncTest, HalfDoubleBpmTest) { mixxx::BeatsPointer pBeats2 = BeatFactory::makeBeatGrid(m_pTrack2->getSampleRate(), 140, 0.0); 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(); @@ -1683,15 +1683,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()); @@ -1721,10 +1721,10 @@ TEST_F(EngineSyncTest, HalfDoubleBpmTest) { 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); @@ -1741,10 +1741,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")) @@ -1780,16 +1780,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()); @@ -1839,12 +1839,12 @@ TEST_F(EngineSyncTest, HalfDoubleThenPlay) { ProcessBuffer(); pButtonSyncEnabled2->slotSet(1.0); pButtonSyncEnabled1->slotSet(1.0); - EXPECT_DOUBLE_EQ(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); @@ -1892,7 +1892,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); @@ -2029,7 +2029,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); @@ -2058,7 +2058,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); @@ -2077,7 +2077,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 @@ -2112,7 +2112,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 @@ -2123,9 +2123,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); @@ -2151,7 +2151,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(), 128, 0.0); m_pTrack1->trySetBeats(pBeats1); @@ -2182,7 +2182,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); @@ -2202,7 +2202,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; @@ -2280,9 +2280,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; @@ -2292,7 +2292,7 @@ TEST_F(EngineSyncTest, FollowerUserTweakPreservedInMasterChange) { mixxx::BeatsPointer pBeats2 = BeatFactory::makeBeatGrid(m_pTrack2->getSampleRate(), 130, 0.0); 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); @@ -2302,7 +2302,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(); @@ -2318,11 +2318,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(); @@ -2332,9 +2332,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; @@ -2344,14 +2344,14 @@ TEST_F(EngineSyncTest, MasterUserTweakPreservedInMasterChange) { mixxx::BeatsPointer pBeats2 = BeatFactory::makeBeatGrid(m_pTrack2->getSampleRate(), 130, 0.0); 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(); @@ -2360,7 +2360,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) { @@ -2371,11 +2371,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(); @@ -2385,7 +2385,7 @@ TEST_F(EngineSyncTest, MasterUserTweakPreservedInMasterChange) { } } -TEST_F(EngineSyncTest, MasterBpmNeverZero) { +TEST_F(EngineSyncTest, LeaderBpmNeverZero) { mixxx::BeatsPointer pBeats1 = BeatFactory::makeBeatGrid(m_pTrack1->getSampleRate(), 128, 0.0); m_pTrack1->trySetBeats(pBeats1); @@ -2650,7 +2650,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"))); @@ -2661,7 +2661,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"))); @@ -2671,8 +2671,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. @@ -2682,9 +2682,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"))); @@ -2697,7 +2697,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(m_pTrack2->getSampleRate(), 75, 0.0); @@ -2705,7 +2705,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 @@ -2730,7 +2730,7 @@ 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_sGroup1, "sync_mode"))->set(SYNC_LEADER_EXPLICIT); ControlObject::getControl(ConfigKey(m_sGroup2, "sync_mode"))->set(SYNC_FOLLOWER); ControlObject::getControl(ConfigKey(m_sGroup1, "play"))->set(1.0); @@ -2765,17 +2765,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); @@ -2786,11 +2786,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(); @@ -2808,26 +2808,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..6e647e57d14 100644 --- a/src/test/synccontroltest.cpp +++ b/src/test/synccontroltest.cpp @@ -1,4 +1,4 @@ -// 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.