diff options
author | Tomaz Canabrava <tomaz.canabrava@gmail.com> | 2016-08-27 21:33:27 -0300 |
---|---|---|
committer | Dirk Hohndel <dirk@hohndel.org> | 2016-08-27 22:32:01 -0700 |
commit | 270864d073359f783fbb9cbe17c583d6b88cb8ae (patch) | |
tree | 855762e7efa34fa6176595e83b124e92756870ce | |
parent | c52688c528602bca5c2f29b2e4d324d5af080512 (diff) | |
download | subsurface-270864d073359f783fbb9cbe17c583d6b88cb8ae.tar.gz |
Settings update: Only set if value changed + bugfixes.
Only set the settings if it actually changes, when the user
clicked on the save button on the preferences, the code would
run in every dialog saving each preferences on disk, but this
is uneeded if the value didn't changed.
Also, while doing that, I found a couple of places where I
used the wrong field, which are now fixed.
Signed-off-by: Tomaz Canabrava <tomaz.canabrava@gmail.com>
Signed-off-by: Dirk Hohndel <dirk@hohndel.org>
-rw-r--r-- | core/subsurface-qt/SettingsObjectWrapper.cpp | 310 |
1 files changed, 300 insertions, 10 deletions
diff --git a/core/subsurface-qt/SettingsObjectWrapper.cpp b/core/subsurface-qt/SettingsObjectWrapper.cpp index e71e1b1e8..f3b156a27 100644 --- a/core/subsurface-qt/SettingsObjectWrapper.cpp +++ b/core/subsurface-qt/SettingsObjectWrapper.cpp @@ -35,6 +35,9 @@ int DiveComputerSettings::downloadMode() const void DiveComputerSettings::setVendor(const QString& vendor) { + if (vendor == prefs.dive_computer.vendor) + return; + QSettings s; s.beginGroup(group); s.setValue("dive_computer_vendor", vendor); @@ -44,6 +47,9 @@ void DiveComputerSettings::setVendor(const QString& vendor) void DiveComputerSettings::setProduct(const QString& product) { + if (product == prefs.dive_computer.product) + return; + QSettings s; s.beginGroup(group); s.setValue("dive_computer_product", product); @@ -53,6 +59,9 @@ void DiveComputerSettings::setProduct(const QString& product) void DiveComputerSettings::setDevice(const QString& device) { + if (device == prefs.dive_computer.device) + return; + QSettings s; s.beginGroup(group); s.setValue("dive_computer_device", device); @@ -62,6 +71,9 @@ void DiveComputerSettings::setDevice(const QString& device) void DiveComputerSettings::setDownloadMode(int mode) { + if (mode == prefs.dive_computer.download_mode) + return; + QSettings s; s.beginGroup(group); s.setValue("dive_computer_download_mode", mode); @@ -95,6 +107,9 @@ QDate UpdateManagerSettings::nextCheck() const void UpdateManagerSettings::setDontCheckForUpdates(bool value) { + if (value == prefs.update_manager.dont_check_for_updates) + return; + QSettings s; s.beginGroup(group); s.setValue("DontCheckForUpdates", value); @@ -103,8 +118,11 @@ void UpdateManagerSettings::setDontCheckForUpdates(bool value) emit dontCheckForUpdatesChanged(value); } -void UpdateManagerSettings::setLastVersionUsed(const QString& value)\ +void UpdateManagerSettings::setLastVersionUsed(const QString& value) { + if (value == prefs.update_manager.last_version_used) + return; + QSettings s; s.beginGroup(group); s.setValue("LastVersionUsed", value); @@ -115,6 +133,9 @@ void UpdateManagerSettings::setLastVersionUsed(const QString& value)\ void UpdateManagerSettings::setNextCheck(const QDate& date) { + if (date.toString() == prefs.update_manager.next_check) + return; + QSettings s; s.beginGroup(group); s.setValue("NextCheck", date); @@ -164,6 +185,9 @@ double PartialPressureGasSettings::pheThreshold() const void PartialPressureGasSettings::setShowPo2(short value) { + if (value == prefs.pp_graphs.po2) + return; + QSettings s; s.beginGroup(tecDetails); s.setValue("po2graph", value); @@ -173,6 +197,9 @@ void PartialPressureGasSettings::setShowPo2(short value) void PartialPressureGasSettings::setShowPn2(short value) { + if (value == prefs.pp_graphs.pn2) + return; + QSettings s; s.beginGroup(tecDetails); s.setValue("pn2graph", value); @@ -182,6 +209,9 @@ void PartialPressureGasSettings::setShowPn2(short value) void PartialPressureGasSettings::setShowPhe(short value) { + if (value == prefs.pp_graphs.phe) + return; + QSettings s; s.beginGroup(tecDetails); s.setValue("phegraph", value); @@ -191,6 +221,9 @@ void PartialPressureGasSettings::setShowPhe(short value) void PartialPressureGasSettings::setPo2Threshold(double value) { + if (value == prefs.pp_graphs.po2_threshold) + return; + QSettings s; s.beginGroup(tecDetails); s.setValue("po2threshold", value); @@ -200,6 +233,9 @@ void PartialPressureGasSettings::setPo2Threshold(double value) void PartialPressureGasSettings::setPn2Threshold(double value) { + if (value == prefs.pp_graphs.pn2_threshold) + return; + QSettings s; s.beginGroup(tecDetails); s.setValue("pn2threshold", value); @@ -209,6 +245,9 @@ void PartialPressureGasSettings::setPn2Threshold(double value) void PartialPressureGasSettings::setPheThreshold(double value) { + if (value == prefs.pp_graphs.phe_threshold) + return; + QSettings s; s.beginGroup(tecDetails); s.setValue("phethreshold", value); @@ -339,6 +378,9 @@ bool TechnicalDetailsSettings::showPicturesInProfile() const void TechnicalDetailsSettings::setModp02(double value) { + if (value == prefs.modpO2) + return; + QSettings s; s.beginGroup(tecDetails); s.setValue("modpO2", value); @@ -348,6 +390,9 @@ void TechnicalDetailsSettings::setModp02(double value) void TechnicalDetailsSettings::setShowPicturesInProfile(bool value) { + if (value == prefs.show_pictures_in_profile) + return; + QSettings s; s.beginGroup(tecDetails); s.setValue("show_pictures_in_profile", value); @@ -357,6 +402,9 @@ void TechnicalDetailsSettings::setShowPicturesInProfile(bool value) void TechnicalDetailsSettings::setEad(bool value) { + if (value == prefs.ead) + return; + QSettings s; s.beginGroup(tecDetails); s.setValue("ead", value); @@ -366,6 +414,9 @@ void TechnicalDetailsSettings::setEad(bool value) void TechnicalDetailsSettings::setMod(bool value) { + if (value == prefs.mod) + return; + QSettings s; s.beginGroup(tecDetails); s.setValue("mod", value); @@ -375,6 +426,9 @@ void TechnicalDetailsSettings::setMod(bool value) void TechnicalDetailsSettings::setDCceiling(bool value) { + if (value == prefs.dcceiling) + return; + QSettings s; s.beginGroup(tecDetails); s.setValue("dcceiling", value); @@ -384,6 +438,9 @@ void TechnicalDetailsSettings::setDCceiling(bool value) void TechnicalDetailsSettings::setRedceiling(bool value) { + if (value == prefs.redceiling) + return; + QSettings s; s.beginGroup(tecDetails); s.setValue("redceiling", value); @@ -393,6 +450,9 @@ void TechnicalDetailsSettings::setRedceiling(bool value) void TechnicalDetailsSettings::setCalcceiling(bool value) { + if (value == prefs.calcceiling) + return; + QSettings s; s.beginGroup(tecDetails); s.setValue("calcceiling", value); @@ -402,6 +462,9 @@ void TechnicalDetailsSettings::setCalcceiling(bool value) void TechnicalDetailsSettings::setCalcceiling3m(bool value) { + if (value == prefs.calcceiling3m) + return; + QSettings s; s.beginGroup(tecDetails); s.setValue("calcceiling3m", value); @@ -411,6 +474,9 @@ void TechnicalDetailsSettings::setCalcceiling3m(bool value) void TechnicalDetailsSettings::setCalcalltissues(bool value) { + if (value == prefs.calcalltissues) + return; + QSettings s; s.beginGroup(tecDetails); s.setValue("calcalltissues", value); @@ -420,6 +486,9 @@ void TechnicalDetailsSettings::setCalcalltissues(bool value) void TechnicalDetailsSettings::setCalcndltts(bool value) { + if (value == prefs.calcndltts) + return; + QSettings s; s.beginGroup(tecDetails); s.setValue("calcndltts", value); @@ -429,6 +498,9 @@ void TechnicalDetailsSettings::setCalcndltts(bool value) void TechnicalDetailsSettings::setGflow(bool value) { + if (value == prefs.gflow) + return; + QSettings s; s.beginGroup(tecDetails); s.setValue("gflow", value); @@ -439,6 +511,9 @@ void TechnicalDetailsSettings::setGflow(bool value) void TechnicalDetailsSettings::setGfhigh(bool value) { + if (value == prefs.gfhigh) + return; + QSettings s; s.beginGroup(tecDetails); s.setValue("gfhigh", value); @@ -449,6 +524,9 @@ void TechnicalDetailsSettings::setGfhigh(bool value) void TechnicalDetailsSettings::setHRgraph(bool value) { + if (value == prefs.hrgraph) + return; + QSettings s; s.beginGroup(tecDetails); s.setValue("hrgraph", value); @@ -458,6 +536,9 @@ void TechnicalDetailsSettings::setHRgraph(bool value) void TechnicalDetailsSettings::setTankBar(bool value) { + if (value == prefs.tankbar) + return; + QSettings s; s.beginGroup(tecDetails); s.setValue("tankbar", value); @@ -467,6 +548,9 @@ void TechnicalDetailsSettings::setTankBar(bool value) void TechnicalDetailsSettings::setPercentageGraph(bool value) { + if (value == prefs.percentagegraph) + return; + QSettings s; s.beginGroup(tecDetails); s.setValue("percentagegraph", value); @@ -476,6 +560,8 @@ void TechnicalDetailsSettings::setPercentageGraph(bool value) void TechnicalDetailsSettings::setRulerGraph(bool value) { + if (value == prefs.rulergraph) + return; /* TODO: search for the QSettings of the RulerBar */ QSettings s; s.beginGroup(tecDetails); @@ -486,6 +572,9 @@ void TechnicalDetailsSettings::setRulerGraph(bool value) void TechnicalDetailsSettings::setShowCCRSetpoint(bool value) { + if (value == prefs.show_ccr_setpoint) + return; + QSettings s; s.beginGroup(tecDetails); s.setValue("show_ccr_setpoint", value); @@ -495,6 +584,8 @@ void TechnicalDetailsSettings::setShowCCRSetpoint(bool value) void TechnicalDetailsSettings::setShowCCRSensors(bool value) { + if (value == prefs.show_ccr_sensors) + return; QSettings s; s.beginGroup(tecDetails); s.setValue("show_ccr_sensors", value); @@ -504,6 +595,8 @@ void TechnicalDetailsSettings::setShowCCRSensors(bool value) void TechnicalDetailsSettings::setZoomedPlot(bool value) { + if (value == prefs.zoomed_plot) + return; QSettings s; s.beginGroup(tecDetails); s.setValue("zoomed_plot", value); @@ -513,6 +606,8 @@ void TechnicalDetailsSettings::setZoomedPlot(bool value) void TechnicalDetailsSettings::setShowSac(bool value) { + if (value == prefs.show_sac) + return; QSettings s; s.beginGroup(tecDetails); s.setValue("show_sac", value); @@ -522,6 +617,8 @@ void TechnicalDetailsSettings::setShowSac(bool value) void TechnicalDetailsSettings::setGfLowAtMaxDepth(bool value) { + if (value == prefs.gf_low_at_maxdepth) + return; QSettings s; s.beginGroup(tecDetails); s.setValue("gf_low_at_maxdepth", value); @@ -532,6 +629,8 @@ void TechnicalDetailsSettings::setGfLowAtMaxDepth(bool value) void TechnicalDetailsSettings::setDisplayUnusedTanks(bool value) { + if (value == prefs.display_unused_tanks) + return; QSettings s; s.beginGroup(tecDetails); s.setValue("display_unused_tanks", value); @@ -541,6 +640,8 @@ void TechnicalDetailsSettings::setDisplayUnusedTanks(bool value) void TechnicalDetailsSettings::setShowAverageDepth(bool value) { + if (value == prefs.show_average_depth) + return; QSettings s; s.beginGroup(tecDetails); s.setValue("show_average_depth", value); @@ -548,8 +649,6 @@ void TechnicalDetailsSettings::setShowAverageDepth(bool value) emit showAverageDepthChanged(value); } - - FacebookSettings::FacebookSettings(QObject *parent) : QObject(parent), group(QStringLiteral("WebApps")), @@ -586,6 +685,8 @@ void FacebookSettings::setAccessToken (const QString& value) void FacebookSettings::setUserId(const QString& value) { + if (value == prefs.facebook.user_id) + return; #if SAVE_FB_CREDENTIALS QSettings s; s.beginGroup(group); @@ -598,6 +699,8 @@ void FacebookSettings::setUserId(const QString& value) void FacebookSettings::setAlbumId(const QString& value) { + if (value == prefs.facebook.album_id) + return; #if SAVE_FB_CREDENTIALS QSettings s; s.beginGroup(group); @@ -648,6 +751,8 @@ taxonomy_category GeocodingPreferences::thirdTaxonomyCategory() const void GeocodingPreferences::setEnableGeocoding(bool value) { + if (value == prefs.geocoding.enable_geocoding) + return; QSettings s; s.beginGroup(group); s.setValue("enable_geocoding", value); @@ -657,6 +762,8 @@ void GeocodingPreferences::setEnableGeocoding(bool value) void GeocodingPreferences::setParseDiveWithoutGps(bool value) { + if (value == prefs.geocoding.parse_dive_without_gps) + return; QSettings s; s.beginGroup(group); s.setValue("parse_dives_without_gps", value); @@ -666,6 +773,8 @@ void GeocodingPreferences::setParseDiveWithoutGps(bool value) void GeocodingPreferences::setTagExistingDives(bool value) { + if (value == prefs.geocoding.tag_existing_dives) + return; QSettings s; s.beginGroup(group); s.setValue("tag_existing_dives", value); @@ -675,28 +784,34 @@ void GeocodingPreferences::setTagExistingDives(bool value) void GeocodingPreferences::setFirstTaxonomyCategory(taxonomy_category value) { + if (value == prefs.geocoding.category[0]) + return; QSettings s; s.beginGroup(group); s.setValue("cat0", value); - prefs.show_average_depth = value; + prefs.geocoding.category[0] = value; emit firstTaxonomyCategoryChanged(value); } void GeocodingPreferences::setSecondTaxonomyCategory(taxonomy_category value) { + if (value == prefs.geocoding.category[1]) + return; QSettings s; s.beginGroup(group); s.setValue("cat1", value); - prefs.show_average_depth = value; + prefs.geocoding.category[1]= value; emit secondTaxonomyCategoryChanged(value); } void GeocodingPreferences::setThirdTaxonomyCategory(taxonomy_category value) { + if (value == prefs.geocoding.category[2]) + return; QSettings s; s.beginGroup(group); s.setValue("cat2", value); - prefs.show_average_depth = value; + prefs.geocoding.category[2] = value; emit thirdTaxonomyCategoryChanged(value); } @@ -738,6 +853,8 @@ QString ProxySettings::pass() const void ProxySettings::setType(int value) { + if (value == prefs.proxy_type) + return; QSettings s; s.beginGroup(group); s.setValue("proxy_type", value); @@ -747,6 +864,8 @@ void ProxySettings::setType(int value) void ProxySettings::setHost(const QString& value) { + if (value == prefs.proxy_host) + return; QSettings s; s.beginGroup(group); s.setValue("proxy_host", value); @@ -757,6 +876,8 @@ void ProxySettings::setHost(const QString& value) void ProxySettings::setPort(int value) { + if (value == prefs.proxy_port) + return; QSettings s; s.beginGroup(group); s.setValue("proxy_port", value); @@ -766,6 +887,8 @@ void ProxySettings::setPort(int value) void ProxySettings::setAuth(short value) { + if (value == prefs.proxy_auth) + return; QSettings s; s.beginGroup(group); s.setValue("proxy_auth", value); @@ -775,6 +898,8 @@ void ProxySettings::setAuth(short value) void ProxySettings::setUser(const QString& value) { + if (value == prefs.proxy_user) + return; QSettings s; s.beginGroup(group); s.setValue("proxy_user", value); @@ -785,6 +910,8 @@ void ProxySettings::setUser(const QString& value) void ProxySettings::setPass(const QString& value) { + if (value == prefs.proxy_pass) + return; QSettings s; s.beginGroup(group); s.setValue("proxy_pass", value); @@ -857,16 +984,20 @@ QString CloudStorageSettings::gitUrl() const void CloudStorageSettings::setPassword(const QString& value) { + if (value == prefs.cloud_storage_password) + return; QSettings s; s.beginGroup(group); s.setValue("password", value); - free(prefs.proxy_pass); - prefs.proxy_pass = copy_string(qPrintable(value)); + free(prefs.cloud_storage_password); + prefs.cloud_storage_password = copy_string(qPrintable(value)); emit passwordChanged(value); } void CloudStorageSettings::setNewPassword(const QString& value) { + if (value == prefs.cloud_storage_newpassword) + return; /*TODO: This looks like wrong, but 'new password' is not saved on disk, why it's on prefs? */ free(prefs.cloud_storage_newpassword); prefs.cloud_storage_newpassword = copy_string(qPrintable(value)); @@ -875,6 +1006,8 @@ void CloudStorageSettings::setNewPassword(const QString& value) void CloudStorageSettings::setEmail(const QString& value) { + if (value == prefs.cloud_storage_email) + return; QSettings s; s.beginGroup(group); s.setValue("email", value); @@ -885,6 +1018,8 @@ void CloudStorageSettings::setEmail(const QString& value) void CloudStorageSettings::setUserId(const QString& value) { + if (value == prefs.userid) + return; //WARNING: UserId is stored outside of any group, but it belongs to Cloud Storage. QSettings s; s.setValue("subsurface_webservice_uid", value); @@ -895,6 +1030,8 @@ void CloudStorageSettings::setUserId(const QString& value) void CloudStorageSettings::setEmailEncoded(const QString& value) { + if (value == prefs.cloud_storage_email_encoded) + return; /*TODO: This looks like wrong, but 'email encoded' is not saved on disk, why it's on prefs? */ free(prefs.cloud_storage_email_encoded); prefs.cloud_storage_email_encoded = copy_string(qPrintable(value)); @@ -903,6 +1040,8 @@ void CloudStorageSettings::setEmailEncoded(const QString& value) void CloudStorageSettings::setSavePasswordLocal(bool value) { + if (value == prefs.save_password_local) + return; QSettings s; s.beginGroup(group); s.setValue("save_password_local", value); @@ -912,6 +1051,8 @@ void CloudStorageSettings::setSavePasswordLocal(bool value) void CloudStorageSettings::setVerificationStatus(short value) { + if (value == prefs.cloud_verification_status) + return; QSettings s; s.beginGroup(group); s.setValue("cloud_verification_status", value); @@ -921,6 +1062,8 @@ void CloudStorageSettings::setVerificationStatus(short value) void CloudStorageSettings::setBackgroundSync(bool value) { + if (value == prefs.cloud_background_sync) + return; QSettings s; s.beginGroup(group); s.setValue("cloud_background_sync", value); @@ -930,6 +1073,9 @@ void CloudStorageSettings::setBackgroundSync(bool value) void CloudStorageSettings::setSaveUserIdLocal(short int value) { + //TODO: this is not saved on disk? + if (value == prefs.save_userid_local) + return; prefs.save_userid_local = value; emit saveUserIdLocalChanged(value); } @@ -941,6 +1087,9 @@ short int CloudStorageSettings::saveUserIdLocal() const void CloudStorageSettings::setBaseUrl(const QString& value) { + if (value == prefs.cloud_base_url) + return; + qDebug() << prefs.cloud_base_url << prefs.cloud_git_url; free((void*)prefs.cloud_base_url); free((void*)prefs.cloud_git_url); prefs.cloud_base_url = copy_string(qPrintable(value)); @@ -954,6 +1103,8 @@ void CloudStorageSettings::setGitUrl(const QString& value) void CloudStorageSettings::setGitLocalOnly(bool value) { + if (value == prefs.git_local_only) + return; prefs.git_local_only = value; emit gitLocalOnlyChanged(value); } @@ -1081,6 +1232,8 @@ deco_mode DivePlannerSettings::decoMode() const void DivePlannerSettings::setLastStop(bool value) { + if (value == prefs.last_stop) + return; QSettings s; s.beginGroup(group); s.setValue("last_stop", value); @@ -1090,6 +1243,9 @@ void DivePlannerSettings::setLastStop(bool value) void DivePlannerSettings::setVerbatimPlan(bool value) { + if (value == prefs.verbatim_plan) + return; + QSettings s; s.beginGroup(group); s.setValue("verbatim_plan", value); @@ -1099,6 +1255,9 @@ void DivePlannerSettings::setVerbatimPlan(bool value) void DivePlannerSettings::setDisplayRuntime(bool value) { + if (value == prefs.display_runtime) + return; + QSettings s; s.beginGroup(group); s.setValue("display_runtime", value); @@ -1108,6 +1267,9 @@ void DivePlannerSettings::setDisplayRuntime(bool value) void DivePlannerSettings::setDisplayDuration(bool value) { + if (value == prefs.display_duration) + return; + QSettings s; s.beginGroup(group); s.setValue("display_duration", value); @@ -1117,6 +1279,9 @@ void DivePlannerSettings::setDisplayDuration(bool value) void DivePlannerSettings::setDisplayTransitions(bool value) { + if (value == prefs.display_transitions) + return; + QSettings s; s.beginGroup(group); s.setValue("display_transitions", value); @@ -1126,6 +1291,8 @@ void DivePlannerSettings::setDisplayTransitions(bool value) void DivePlannerSettings::setDoo2breaks(bool value) { + if (value == prefs.doo2breaks) + return; QSettings s; s.beginGroup(group); s.setValue("doo2breaks", value); @@ -1135,6 +1302,8 @@ void DivePlannerSettings::setDoo2breaks(bool value) void DivePlannerSettings::setDropStoneMode(bool value) { + if (value == prefs.drop_stone_mode) + return; QSettings s; s.beginGroup(group); s.setValue("drop_stone_mode", value); @@ -1144,6 +1313,8 @@ void DivePlannerSettings::setDropStoneMode(bool value) void DivePlannerSettings::setSafetyStop(bool value) { + if (value == prefs.safetystop) + return; QSettings s; s.beginGroup(group); s.setValue("safetystop", value); @@ -1153,6 +1324,8 @@ void DivePlannerSettings::setSafetyStop(bool value) void DivePlannerSettings::setSwitchAtRequiredStop(bool value) { + if (value == prefs.switch_at_req_stop) + return; QSettings s; s.beginGroup(group); s.setValue("switch_at_req_stop", value); @@ -1162,6 +1335,8 @@ void DivePlannerSettings::setSwitchAtRequiredStop(bool value) void DivePlannerSettings::setAscrate75(int value) { + if (value == prefs.ascrate75) + return; QSettings s; s.beginGroup(group); s.setValue("ascrate75", value); @@ -1171,6 +1346,9 @@ void DivePlannerSettings::setAscrate75(int value) void DivePlannerSettings::setAscrate50(int value) { + if (value == prefs.ascrate50) + return; + QSettings s; s.beginGroup(group); s.setValue("ascrate50", value); @@ -1180,6 +1358,8 @@ void DivePlannerSettings::setAscrate50(int value) void DivePlannerSettings::setAscratestops(int value) { + if (value == prefs.ascratestops) + return; QSettings s; s.beginGroup(group); s.setValue("ascratestops", value); @@ -1189,6 +1369,9 @@ void DivePlannerSettings::setAscratestops(int value) void DivePlannerSettings::setAscratelast6m(int value) { + if (value == prefs.ascratelast6m) + return; + QSettings s; s.beginGroup(group); s.setValue("ascratelast6m", value); @@ -1198,6 +1381,9 @@ void DivePlannerSettings::setAscratelast6m(int value) void DivePlannerSettings::setDescrate(int value) { + if (value == prefs.descrate) + return; + QSettings s; s.beginGroup(group); s.setValue("descrate", value); @@ -1207,6 +1393,9 @@ void DivePlannerSettings::setDescrate(int value) void DivePlannerSettings::setBottompo2(int value) { + if (value == prefs.bottompo2) + return; + QSettings s; s.beginGroup(group); s.setValue("bottompo2", value); @@ -1216,6 +1405,9 @@ void DivePlannerSettings::setBottompo2(int value) void DivePlannerSettings::setDecopo2(int value) { + if (value == prefs.decopo2) + return; + QSettings s; s.beginGroup(group); s.setValue("decopo2", value); @@ -1225,6 +1417,9 @@ void DivePlannerSettings::setDecopo2(int value) void DivePlannerSettings::setBestmixend(int value) { + if (value == prefs.bestmixend.mm) + return; + QSettings s; s.beginGroup(group); s.setValue("bestmixend", value); @@ -1234,6 +1429,9 @@ void DivePlannerSettings::setBestmixend(int value) void DivePlannerSettings::setReserveGas(int value) { + if (value == prefs.reserve_gas) + return; + QSettings s; s.beginGroup(group); s.setValue("reserve_gas", value); @@ -1243,6 +1441,9 @@ void DivePlannerSettings::setReserveGas(int value) void DivePlannerSettings::setMinSwitchDuration(int value) { + if (value == prefs.min_switch_duration) + return; + QSettings s; s.beginGroup(group); s.setValue("min_switch_duration", value); @@ -1252,6 +1453,9 @@ void DivePlannerSettings::setMinSwitchDuration(int value) void DivePlannerSettings::setBottomSac(int value) { + if (value == prefs.bottomsac) + return; + QSettings s; s.beginGroup(group); s.setValue("bottomsac", value); @@ -1261,6 +1465,9 @@ void DivePlannerSettings::setBottomSac(int value) void DivePlannerSettings::setSecoSac(int value) { + if (value == prefs.decosac) + return; + QSettings s; s.beginGroup(group); s.setValue("decosac", value); @@ -1270,6 +1477,9 @@ void DivePlannerSettings::setSecoSac(int value) void DivePlannerSettings::setConservatismLevel(int value) { + if (value == prefs.conservatism_level) + return; + QSettings s; s.beginGroup(group); s.setValue("conservatism", value); @@ -1279,6 +1489,9 @@ void DivePlannerSettings::setConservatismLevel(int value) void DivePlannerSettings::setDecoMode(deco_mode value) { + if (value == prefs.deco_mode) + return; + QSettings s; s.beginGroup(group); s.setValue("deco_mode", value); @@ -1335,6 +1548,9 @@ bool UnitsSettings::coordinatesTraditional() const void UnitsSettings::setLength(int value) { + if (value == prefs.units.length) + return; + QSettings s; s.beginGroup(group); s.setValue("length", value); @@ -1344,6 +1560,8 @@ void UnitsSettings::setLength(int value) void UnitsSettings::setPressure(int value) { + if (value == prefs.units.pressure) + return; QSettings s; s.beginGroup(group); s.setValue("pressure", value); @@ -1353,6 +1571,8 @@ void UnitsSettings::setPressure(int value) void UnitsSettings::setVolume(int value) { + if (value == prefs.units.volume) + return; QSettings s; s.beginGroup(group); s.setValue("volume", value); @@ -1362,6 +1582,8 @@ void UnitsSettings::setVolume(int value) void UnitsSettings::setTemperature(int value) { + if (value == prefs.units.temperature) + return; QSettings s; s.beginGroup(group); s.setValue("temperature", value); @@ -1371,6 +1593,8 @@ void UnitsSettings::setTemperature(int value) void UnitsSettings::setWeight(int value) { + if (value == prefs.units.weight) + return; QSettings s; s.beginGroup(group); s.setValue("weight", value); @@ -1380,6 +1604,8 @@ void UnitsSettings::setWeight(int value) void UnitsSettings::setVerticalSpeedTime(int value) { + if (value == prefs.units.vertical_speed_time) + return; QSettings s; s.beginGroup(group); s.setValue("vertical_speed_time", value); @@ -1389,6 +1615,8 @@ void UnitsSettings::setVerticalSpeedTime(int value) void UnitsSettings::setCoordinatesTraditional(bool value) { + if (value == prefs.coordinates_traditional) + return; QSettings s; s.setValue("coordinates", value); prefs.coordinates_traditional = value; @@ -1397,6 +1625,13 @@ void UnitsSettings::setCoordinatesTraditional(bool value) void UnitsSettings::setUnitSystem(const QString& value) { + short int v = value == QStringLiteral("metric") ? METRIC + : value == QStringLiteral("imperial")? IMPERIAL + : PERSONALIZE; + + if (v == prefs.unit_system) + return; + QSettings s; s.setValue("unit_system", value); @@ -1457,6 +1692,9 @@ int GeneralSettingsObjectWrapper::pscrRatio() const void GeneralSettingsObjectWrapper::setDefaultFilename(const QString& value) { + if (value == prefs.default_filename) + return; + QSettings s; s.beginGroup(group); s.setValue("default_filename", value); @@ -1466,6 +1704,9 @@ void GeneralSettingsObjectWrapper::setDefaultFilename(const QString& value) void GeneralSettingsObjectWrapper::setDefaultCylinder(const QString& value) { + if (value == prefs.default_cylinder) + return; + QSettings s; s.beginGroup(group); s.setValue("default_cylinder", value); @@ -1475,6 +1716,9 @@ void GeneralSettingsObjectWrapper::setDefaultCylinder(const QString& value) void GeneralSettingsObjectWrapper::setDefaultFileBehavior(short value) { + if (value == prefs.default_file_behavior && prefs.default_file_behavior != UNDEFINED_DEFAULT_FILE) + return; + QSettings s; s.beginGroup(group); s.setValue("default_file_behavior", value); @@ -1492,6 +1736,9 @@ void GeneralSettingsObjectWrapper::setDefaultFileBehavior(short value) void GeneralSettingsObjectWrapper::setUseDefaultFile(bool value) { + if (value == prefs.use_default_file) + return; + QSettings s; s.beginGroup(group); s.setValue("use_default_file", value); @@ -1501,6 +1748,9 @@ void GeneralSettingsObjectWrapper::setUseDefaultFile(bool value) void GeneralSettingsObjectWrapper::setDefaultSetPoint(int value) { + if (value == prefs.defaultsetpoint) + return; + QSettings s; s.beginGroup(group); s.setValue("defaultsetpoint", value); @@ -1510,6 +1760,8 @@ void GeneralSettingsObjectWrapper::setDefaultSetPoint(int value) void GeneralSettingsObjectWrapper::setO2Consumption(int value) { + if (value == prefs.o2consumption) + return; QSettings s; s.beginGroup(group); s.setValue("o2consumption", value); @@ -1519,6 +1771,8 @@ void GeneralSettingsObjectWrapper::setO2Consumption(int value) void GeneralSettingsObjectWrapper::setPscrRatio(int value) { + if (value == prefs.pscr_ratio) + return; QSettings s; s.beginGroup(group); s.setValue("pscr_ratio", value); @@ -1549,12 +1803,17 @@ short DisplaySettingsObjectWrapper::displayInvalidDives() const void DisplaySettingsObjectWrapper::setDivelistFont(const QString& value) { - QSettings s; - s.setValue("divelist_font", value); + QString newValue = value; if (value.contains(",")) newValue = value.left(value.indexOf(",")); + if (newValue == prefs.divelist_font) + return; + + QSettings s; + s.setValue("divelist_font", value); + if (!subsurface_ignore_font(newValue.toUtf8().constData())) { free((void *)prefs.divelist_font); prefs.divelist_font = strdup(newValue.toUtf8().constData()); @@ -1565,6 +1824,9 @@ void DisplaySettingsObjectWrapper::setDivelistFont(const QString& value) void DisplaySettingsObjectWrapper::setFontSize(double value) { + if (value == prefs.font_size) + return; + QSettings s; s.setValue("font_size", value); prefs.font_size = value; @@ -1576,6 +1838,9 @@ void DisplaySettingsObjectWrapper::setFontSize(double value) void DisplaySettingsObjectWrapper::setDisplayInvalidDives(short value) { + if (value == prefs.display_invalid_dives) + return; + QSettings s; s.setValue("displayinvalid", value); prefs.display_invalid_dives = value; @@ -1625,6 +1890,8 @@ bool LanguageSettingsObjectWrapper::useSystemLanguage() const void LanguageSettingsObjectWrapper::setUseSystemLanguage(bool value) { + if (value == prefs.locale.use_system_language) + return; QSettings s; s.setValue("UseSystemLanguage", value); prefs.locale.use_system_language = copy_string(qPrintable(value)); @@ -1633,6 +1900,8 @@ void LanguageSettingsObjectWrapper::setUseSystemLanguage(bool value) void LanguageSettingsObjectWrapper::setLanguage(const QString& value) { + if (value == prefs.locale.language) + return; QSettings s; s.setValue("UiLanguage", value); prefs.locale.language = copy_string(qPrintable(value)); @@ -1641,6 +1910,8 @@ void LanguageSettingsObjectWrapper::setLanguage(const QString& value) void LanguageSettingsObjectWrapper::setTimeFormat(const QString& value) { + if (value == prefs.time_format) + return; QSettings s; s.setValue("time_format", value); prefs.time_format = copy_string(qPrintable(value));; @@ -1649,6 +1920,9 @@ void LanguageSettingsObjectWrapper::setTimeFormat(const QString& value) void LanguageSettingsObjectWrapper::setDateFormat(const QString& value) { + if (value == prefs.date_format) + return; + QSettings s; s.setValue("date_format", value); prefs.date_format = copy_string(qPrintable(value));; @@ -1657,6 +1931,9 @@ void LanguageSettingsObjectWrapper::setDateFormat(const QString& value) void LanguageSettingsObjectWrapper::setDateFormatShort(const QString& value) { + if (value == prefs.date_format_short) + return; + QSettings s; s.setValue("date_format_short", value); prefs.date_format_short = copy_string(qPrintable(value));; @@ -1665,6 +1942,8 @@ void LanguageSettingsObjectWrapper::setDateFormatShort(const QString& value) void LanguageSettingsObjectWrapper::setTimeFormatOverride(bool value) { + if (value == prefs.time_format_override) + return; QSettings s; s.setValue("time_format_override", value); prefs.time_format_override = value; @@ -1673,6 +1952,9 @@ void LanguageSettingsObjectWrapper::setTimeFormatOverride(bool value) void LanguageSettingsObjectWrapper::setDateFormatOverride(bool value) { + if (value == prefs.date_format_override) + return; + QSettings s; s.setValue("date_format_override", value); prefs.date_format_override = value; @@ -1693,6 +1975,9 @@ int AnimationsSettingsObjectWrapper::animationSpeed() const void AnimationsSettingsObjectWrapper::setAnimationSpeed(int value) { + if (value == prefs.animation_speed) + return; + QSettings s; s.setValue("animation_speed", value); prefs.animation_speed = value; @@ -1717,6 +2002,8 @@ int LocationServiceSettingsObjectWrapper::timeThreshold() const void LocationServiceSettingsObjectWrapper::setDistanceThreshold(int value) { + if (value == prefs.distance_threshold) + return; QSettings s; s.setValue("distance_threshold", value); prefs.distance_threshold = value; @@ -1725,6 +2012,9 @@ void LocationServiceSettingsObjectWrapper::setDistanceThreshold(int value) void LocationServiceSettingsObjectWrapper::setTimeThreshold(int value) { + if (value == prefs.time_threshold) + return; + QSettings s; s.setValue("time_threshold", value); prefs.time_threshold = value; |