mirror of
				https://github.com/subsurface/subsurface.git
				synced 2025-02-19 22:16:15 +00:00 
			
		
		
		
	Settings QObjectification: dive planner preferences
Signed-off-by: Tomaz Canabrava <tomaz.canabrava@intel.com> Signed-off-by: Dirk Hohndel <dirk@hohndel.org>
This commit is contained in:
		
							parent
							
								
									7b5656a08b
								
							
						
					
					
						commit
						8e61c36ca7
					
				
					 2 changed files with 390 additions and 9 deletions
				
			
		|  | @ -749,7 +749,6 @@ void CloudStorageSettings::setSavePasswordLocal(bool value) | |||
| 	QSettings s; | ||||
| 	s.beginGroup(group); | ||||
| 	s.setValue("save_password_local", value); | ||||
| 	free(prefs.save_password_local); | ||||
| 	prefs.save_password_local = value; | ||||
| 	emit savePasswordLocalChanged(value); | ||||
| } | ||||
|  | @ -759,7 +758,6 @@ void CloudStorageSettings::setVerificationStatus(short value) | |||
| 	QSettings s; | ||||
| 	s.beginGroup(group); | ||||
| 	s.setValue("cloud_verification_status", value); | ||||
| 	free(prefs.cloud_verification_status); | ||||
| 	prefs.cloud_verification_status = value; | ||||
| 	emit verificationStatusChanged(value); | ||||
| } | ||||
|  | @ -769,8 +767,7 @@ void CloudStorageSettings::setBackgroundSync(bool value) | |||
| 	QSettings s; | ||||
| 	s.beginGroup(group); | ||||
| 	s.setValue("cloud_background_sync", value); | ||||
| 	free(prefs.cloud_background_sync); | ||||
| 	prefs.cloud_background_sync = copy_string(qPrintable(value)); | ||||
| 	prefs.cloud_background_sync = value; | ||||
| 	emit backgroundSyncChanged(value); | ||||
| } | ||||
| 
 | ||||
|  | @ -786,3 +783,317 @@ void CloudStorageSettings::setCloudUrl(const QString& value) /* no-op */ | |||
| { | ||||
| 	Q_UNUSED(value); | ||||
| } | ||||
| 
 | ||||
| DivePlannerSettings::DivePlannerSettings(QObject *parent) : | ||||
| 	QObject(parent), | ||||
| 	group(QStringLiteral("Planner")) | ||||
| { | ||||
| } | ||||
| 
 | ||||
| bool DivePlannerSettings::lastStop() const | ||||
| { | ||||
| 	return prefs.last_stop; | ||||
| } | ||||
| 
 | ||||
| bool DivePlannerSettings::verbatimPlan() const | ||||
| { | ||||
| 	return prefs.verbatim_plan; | ||||
| } | ||||
| 
 | ||||
| bool DivePlannerSettings::displayRuntime() const | ||||
| { | ||||
| 	return prefs.display_runtime; | ||||
| } | ||||
| 
 | ||||
| bool DivePlannerSettings::displayDuration() const | ||||
| { | ||||
| 	return prefs.display_duration; | ||||
| } | ||||
| 
 | ||||
| bool DivePlannerSettings::displayTransitions() const | ||||
| { | ||||
| 	return prefs.display_transitions; | ||||
| } | ||||
| 
 | ||||
| bool DivePlannerSettings::doo2breaks() const | ||||
| { | ||||
| 	return prefs.doo2breaks; | ||||
| } | ||||
| 
 | ||||
| bool DivePlannerSettings::dropStoneMode() const | ||||
| { | ||||
| 	return prefs.drop_stone_mode; | ||||
| } | ||||
| 
 | ||||
| bool DivePlannerSettings::safetyStop() const | ||||
| { | ||||
| 	return prefs.safetystop; | ||||
| } | ||||
| 
 | ||||
| bool DivePlannerSettings::switchAtRequiredStop() const | ||||
| { | ||||
| 	return prefs.switch_at_req_stop; | ||||
| } | ||||
| 
 | ||||
| int DivePlannerSettings::ascrate75() const | ||||
| { | ||||
| 	return prefs.ascrate75; | ||||
| } | ||||
| 
 | ||||
| int DivePlannerSettings::ascrate50() const | ||||
| { | ||||
| 	return prefs.ascrate50; | ||||
| } | ||||
| 
 | ||||
| int DivePlannerSettings::ascratestops() const | ||||
| { | ||||
| 	return prefs.ascratestops; | ||||
| } | ||||
| 
 | ||||
| int DivePlannerSettings::ascratelast6m() const | ||||
| { | ||||
| 	return prefs.ascratelast6m; | ||||
| } | ||||
| 
 | ||||
| int DivePlannerSettings::descrate() const | ||||
| { | ||||
| 	return prefs.descrate; | ||||
| } | ||||
| 
 | ||||
| int DivePlannerSettings::bottompo2() const | ||||
| { | ||||
| 	return prefs.bottompo2; | ||||
| } | ||||
| 
 | ||||
| int DivePlannerSettings::decopo2() const | ||||
| { | ||||
| 	return prefs.decopo2; | ||||
| } | ||||
| 
 | ||||
| int DivePlannerSettings::reserveGas() const | ||||
| { | ||||
| 	return prefs.reserve_gas; | ||||
| } | ||||
| 
 | ||||
| int DivePlannerSettings::minSwitchDuration() const | ||||
| { | ||||
| 	return prefs.min_switch_duration; | ||||
| } | ||||
| 
 | ||||
| int DivePlannerSettings::bottomSac() const | ||||
| { | ||||
| 	return prefs.bottomsac; | ||||
| } | ||||
| 
 | ||||
| int DivePlannerSettings::decoSac() const | ||||
| { | ||||
| 	return prefs.decosac; | ||||
| } | ||||
| 
 | ||||
| short DivePlannerSettings::conservatismLevel() const | ||||
| { | ||||
| 	return prefs.conservatism_level; | ||||
| } | ||||
| 
 | ||||
| deco_mode DivePlannerSettings::decoMode() const | ||||
| { | ||||
| 	return prefs.deco_mode; | ||||
| } | ||||
| 
 | ||||
| void DivePlannerSettings::setLastStop(bool value) | ||||
| { | ||||
| 	QSettings s; | ||||
| 	s.beginGroup(group); | ||||
| 	s.setValue("last_stop", value); | ||||
| 	prefs.last_stop = value; | ||||
| 	emit lastStopChanged(value); | ||||
| } | ||||
| 
 | ||||
| void DivePlannerSettings::setVerbatimPlan(bool value) | ||||
| { | ||||
| 	QSettings s; | ||||
| 	s.beginGroup(group); | ||||
| 	s.setValue("verbatim_plan", value); | ||||
| 	prefs.verbatim_plan = value; | ||||
| 	emit verbatimPlanChanged(value); | ||||
| } | ||||
| 
 | ||||
| void DivePlannerSettings::setDisplayRuntime(bool value) | ||||
| { | ||||
| 	QSettings s; | ||||
| 	s.beginGroup(group); | ||||
| 	s.setValue("display_runtime", value); | ||||
| 	prefs.display_runtime = value; | ||||
| 	emit displayRuntimeChanged(value); | ||||
| } | ||||
| 
 | ||||
| void DivePlannerSettings::setDisplayDuration(bool value) | ||||
| { | ||||
| 	QSettings s; | ||||
| 	s.beginGroup(group); | ||||
| 	s.setValue("display_duration", value); | ||||
| 	prefs.display_duration = value; | ||||
| 	emit displayDurationChanged(value); | ||||
| } | ||||
| 
 | ||||
| void DivePlannerSettings::setDisplayTransitions(bool value) | ||||
| { | ||||
| 	QSettings s; | ||||
| 	s.beginGroup(group); | ||||
| 	s.setValue("display_transitions", value); | ||||
| 	prefs.display_transitions = value; | ||||
| 	emit displayTransitionsChanged(value); | ||||
| } | ||||
| 
 | ||||
| void DivePlannerSettings::setDoo2breaks(bool value) | ||||
| { | ||||
| 	QSettings s; | ||||
| 	s.beginGroup(group); | ||||
| 	s.setValue("doo2breaks", value); | ||||
| 	prefs.doo2breaks = value; | ||||
| 	emit doo2breaksChanged(value); | ||||
| } | ||||
| 
 | ||||
| void DivePlannerSettings::setDropStoneMode(bool value) | ||||
| { | ||||
| 	QSettings s; | ||||
| 	s.beginGroup(group); | ||||
| 	s.setValue("drop_stone_mode", value); | ||||
| 	prefs.drop_stone_mode = value; | ||||
| 	emit dropStoneModeChanged(value); | ||||
| } | ||||
| 
 | ||||
| void DivePlannerSettings::setSafetyStop(bool value) | ||||
| { | ||||
| 	QSettings s; | ||||
| 	s.beginGroup(group); | ||||
| 	s.setValue("safetystop", value); | ||||
| 	prefs.safetystop = value; | ||||
| 	emit safetyStopChanged(value); | ||||
| } | ||||
| 
 | ||||
| void DivePlannerSettings::setSwitchAtRequiredStop(bool value) | ||||
| { | ||||
| 	QSettings s; | ||||
| 	s.beginGroup(group); | ||||
| 	s.setValue("switch_at_req_stop", value); | ||||
| 	prefs.switch_at_req_stop = value; | ||||
| 	emit switchAtRequiredStopChanged(value); | ||||
| } | ||||
| 
 | ||||
| void DivePlannerSettings::setAscrate75(int value) | ||||
| { | ||||
| 	QSettings s; | ||||
| 	s.beginGroup(group); | ||||
| 	s.setValue("ascrate75", value); | ||||
| 	prefs.ascrate75 = value; | ||||
| 	emit ascrate75Changed(value); | ||||
| } | ||||
| 
 | ||||
| void DivePlannerSettings::setAscrate50(int value) | ||||
| { | ||||
| 	QSettings s; | ||||
| 	s.beginGroup(group); | ||||
| 	s.setValue("ascrate50", value); | ||||
| 	prefs.ascrate50 = value; | ||||
| 	emit ascrate50Changed(value); | ||||
| } | ||||
| 
 | ||||
| void DivePlannerSettings::setAscratestops(int value) | ||||
| { | ||||
| 	QSettings s; | ||||
| 	s.beginGroup(group); | ||||
| 	s.setValue("ascratestops", value); | ||||
| 	prefs.ascratestops = value; | ||||
| 	emit ascratestopsChanged(value); | ||||
| } | ||||
| 
 | ||||
| void DivePlannerSettings::setAscratelast6m(int value) | ||||
| { | ||||
| 	QSettings s; | ||||
| 	s.beginGroup(group); | ||||
| 	s.setValue("ascratelast6m", value); | ||||
| 	prefs.ascratelast6m = value; | ||||
| 	emit ascratelast6mChanged(); | ||||
| } | ||||
| 
 | ||||
| void DivePlannerSettings::setDescrate(int value) | ||||
| { | ||||
| 	QSettings s; | ||||
| 	s.beginGroup(group); | ||||
| 	s.setValue("descrate", value); | ||||
| 	prefs.descrate = value; | ||||
| 	emit descrateChanged(value); | ||||
| } | ||||
| 
 | ||||
| void DivePlannerSettings::setBottompo2(int value) | ||||
| { | ||||
| 	QSettings s; | ||||
| 	s.beginGroup(group); | ||||
| 	s.setValue("bottompo2", value); | ||||
| 	prefs.bottompo2 = value; | ||||
| 	emit bottompo2Changed(value); | ||||
| } | ||||
| 
 | ||||
| void DivePlannerSettings::setDecopo2(int value) | ||||
| { | ||||
| 	QSettings s; | ||||
| 	s.beginGroup(group); | ||||
| 	s.setValue("decopo2", value); | ||||
| 	prefs.decopo2 = value; | ||||
| 	emit decopo2Changed(value); | ||||
| } | ||||
| 
 | ||||
| void DivePlannerSettings::setReserveGas(int value) | ||||
| { | ||||
| 	QSettings s; | ||||
| 	s.beginGroup(group); | ||||
| 	s.setValue("reserve_gas", value); | ||||
| 	prefs.reserve_gas = value; | ||||
| 	emit reserveGasChanged(value); | ||||
| } | ||||
| 
 | ||||
| void DivePlannerSettings::setMinSwitchDuration(int value) | ||||
| { | ||||
| 	QSettings s; | ||||
| 	s.beginGroup(group); | ||||
| 	s.setValue("min_switch_duration", value); | ||||
| 	prefs.min_switch_duration = value; | ||||
| 	emit minSwitchDurationChanged(value); | ||||
| } | ||||
| 
 | ||||
| void DivePlannerSettings::setBottomSac(int value) | ||||
| { | ||||
| 	QSettings s; | ||||
| 	s.beginGroup(group); | ||||
| 	s.setValue("bottomsac", value); | ||||
| 	prefs.bottomsac = value; | ||||
| 	emit bottomSacChanged(value); | ||||
| } | ||||
| 
 | ||||
| void DivePlannerSettings::setSecoSac(int value) | ||||
| { | ||||
| 	QSettings s; | ||||
| 	s.beginGroup(group); | ||||
| 	s.setValue("decosac", value); | ||||
| 	prefs.decosac = value; | ||||
| 	emit decoSacChanged(value); | ||||
| } | ||||
| 
 | ||||
| void DivePlannerSettings::setConservatismLevel(int value) | ||||
| { | ||||
| 	QSettings s; | ||||
| 	s.beginGroup(group); | ||||
| 	s.setValue("conservatism", value); | ||||
| 	prefs.conservatism_level = value; | ||||
| 	emit conservatismLevelChanged(value); | ||||
| } | ||||
| 
 | ||||
| void DivePlannerSettings::setDecoMode(deco_mode value) | ||||
| { | ||||
| 	QSettings s; | ||||
| 	s.beginGroup(group); | ||||
| 	s.setValue("deco_mode", value); | ||||
| 	prefs.deco_mode = value.; | ||||
| 	emit decoModeChanged(value); | ||||
| } | ||||
|  |  | |||
|  | @ -320,14 +320,84 @@ class DivePlannerSettings : public QObject { | |||
| 	Q_PROPERTY(int min_switch_duration  READ minSwitchDuration    WRITE setMinSwitchDuration    NOTIFY minSwitchDurationChanged) | ||||
| 	Q_PROPERTY(int bottomsac            READ bottomSac            WRITE setBottomSac            NOTIFY bottomSacChanged) | ||||
| 	Q_PROPERTY(int decosac              READ decoSac              WRITE setSecoSac              NOTIFY decoSacChanged) | ||||
| 	Q_PROPERTY(short conservatism_level READ conservatism_level   WRITE setConservatismLevel    NOTIFY conservatismLevelChanged) | ||||
| 	Q_PROPERTY(short conservatism_level READ conservatismLevel    WRITE setConservatismLevel    NOTIFY conservatismLevelChanged) | ||||
| 	Q_PROPERTY(deco_mode decoMode       READ decoMode             WRITE setDecoMode             NOTIFY decoModeChanged) | ||||
| 
 | ||||
| public: | ||||
| 	DivePlannerSettings(QObject *parent = 0); | ||||
| 	bool lastStop() const; | ||||
| 	bool verbatimPlan() const; | ||||
| 	bool displayRuntime() const; | ||||
| 	bool displayDuration() const; | ||||
| 	bool displayTransitions() const; | ||||
| 	bool doo2breaks() const; | ||||
| 	bool dropStoneMode() const; | ||||
| 	bool safetyStop() const; | ||||
| 	bool switchAtRequiredStop() const; | ||||
| 	int ascrate75() const; | ||||
| 	int ascrate50() const; | ||||
| 	int ascratestops() const; | ||||
| 	int ascratelast6m() const; | ||||
| 	int descrate() const; | ||||
| 	int bottompo2() const; | ||||
| 	int decopo2() const; | ||||
| 	int reserveGas() const; | ||||
| 	int minSwitchDuration() const; | ||||
| 	int bottomSac() const; | ||||
| 	int decoSac() const; | ||||
| 	short conservatismLevel() const; | ||||
| 	deco_mode decoMode() const; | ||||
| 
 | ||||
| public slots: | ||||
| 	void setLastStop(bool value); | ||||
| 	void setVerbatimPlan(bool value); | ||||
| 	void setDisplayRuntime(bool value); | ||||
| 	void setDisplayDuration(bool value); | ||||
| 	void setDisplayTransitions(bool value); | ||||
| 	void setDoo2breaks(bool value); | ||||
| 	void setDropStoneMode(bool value); | ||||
| 	void setSafetyStop(bool value); | ||||
| 	void setSwitchAtRequiredStop(bool value); | ||||
| 	void setAscrate75(int value); | ||||
| 	void setAscrate50(int value); | ||||
| 	void setAscratestops(int value); | ||||
| 	void setAscratelast6m(int value); | ||||
| 	void setDescrate(int value); | ||||
| 	void setBottompo2(int value); | ||||
| 	void setDecopo2(int value); | ||||
| 	void setReserveGas(int value); | ||||
| 	void setMinSwitchDuration(int value); | ||||
| 	void setBottomSac(int value); | ||||
| 	void setSecoSac(int value); | ||||
| 	void setConservatismLevel(int value); | ||||
| 	void setDecoMode(deco_mode value); | ||||
| 
 | ||||
| signals: | ||||
| 	void lastStopChanged(bool value); | ||||
| 	void verbatimPlanChanged(bool value); | ||||
| 	void displayRuntimeChanged(bool value); | ||||
| 	void displayDurationChanged(bool value); | ||||
| 	void displayTransitionsChanged(bool value); | ||||
| 	void doo2breaksChanged(bool value); | ||||
| 	void dropStoneModeChanged(bool value); | ||||
| 	void safetyStopChanged(bool value); | ||||
| 	void switchAtRequiredStopChanged(bool value); | ||||
| 	void ascrate75Changed(int value); | ||||
| 	void ascrate50Changed(int value); | ||||
| 	void ascratestopsChanged(int value); | ||||
| 	void ascratelast6mChanged(int value); | ||||
| 	void descrateChanged(int value); | ||||
| 	void bottompo2Changed(int value); | ||||
| 	void decopo2Changed(int value); | ||||
| 	void reserveGasChanged(int value); | ||||
| 	void minSwitchDurationChanged(int value); | ||||
| 	void bottomSacChanged(int value); | ||||
| 	void decoSacChanged(int value); | ||||
| 	void conservatismLevelChanged(int value); | ||||
| 	void decoModeChanged(deco_mode value); | ||||
| 
 | ||||
| private: | ||||
| 	QString group; | ||||
| 
 | ||||
| 	// Decompression Mode
 | ||||
| 	enum deco_mode deco_mode; | ||||
| }; | ||||
| }; | ||||
| /* Monster class, should be breaken into a few more understandable classes later, wich will be easy to do:
 | ||||
| * grab the Q_PROPERTYES and create a wrapper class like the ones above. | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue