/////////////////////////////////////////////////////////////////////////////////// // Copyright (C) 2019 Edouard Griffiths, F4EXB // // // // This program is free software; you can redistribute it and/or modify // // it under the terms of the GNU General Public License as published by // // the Free Software Foundation as version 3 of the License, or // // (at your option) any later version. // // // // This program is distributed in the hope that it will be useful, // // but WITHOUT ANY WARRANTY; without even the implied warranty of // // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the // // GNU General Public License V3 for more details. // // // // You should have received a copy of the GNU General Public License // // along with this program. If not, see . // /////////////////////////////////////////////////////////////////////////////////// #include "util/simpleserializer.h" #include "testmosyncsettings.h" const unsigned int TestMOSyncSettings::m_msThrottle = 50U; TestMOSyncSettings::TestMOSyncSettings() { resetToDefaults(); } void TestMOSyncSettings::resetToDefaults() { m_centerFrequency = 435000*1000; m_sampleRate = 48000; m_log2Interp = 0; m_fcPosTx = FC_POS_CENTER; } QByteArray TestMOSyncSettings::serialize() const { SimpleSerializer s(1); s.writeU64(1, m_sampleRate); s.writeU32(2, m_log2Interp); s.writeS32(3, (int) m_fcPosTx); return s.final(); } bool TestMOSyncSettings::deserialize(const QByteArray& data) { SimpleDeserializer d(data); if (!d.isValid()) { resetToDefaults(); return false; } if (d.getVersion() == 1) { int intval; d.readU64(1, &m_sampleRate, 48000); d.readU32(2, &m_log2Interp, 0); d.readS32(38, &intval, 2); m_fcPosTx = (fcPos_t) intval; return true; } else { resetToDefaults(); return false; } }