| 
									
										
										
										
											2017-04-27 20:27:59 +02:00
										 |  |  | // SPDX-License-Identifier: GPL-2.0
 | 
					
						
							| 
									
										
										
										
											2013-09-09 05:59:03 -03:00
										 |  |  | /* main.c */ | 
					
						
							|  |  |  | #include <locale.h>
 | 
					
						
							|  |  |  | #include <stdio.h>
 | 
					
						
							|  |  |  | #include <stdlib.h>
 | 
					
						
							| 
									
										
										
										
											2018-07-25 18:36:40 -07:00
										 |  |  | #include <string.h>
 | 
					
						
							| 
									
										
										
										
											2013-09-09 05:59:03 -03:00
										 |  |  | #include <time.h>
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-04-04 22:02:03 -07:00
										 |  |  | #include "core/color.h"
 | 
					
						
							| 
									
										
										
										
											2017-04-27 20:24:14 +02:00
										 |  |  | #include "core/downloadfromdcthread.h"
 | 
					
						
							| 
									
										
										
										
											2018-07-25 18:36:40 -07:00
										 |  |  | #include "core/qt-gui.h"
 | 
					
						
							|  |  |  | #include "core/qthelper.h"
 | 
					
						
							|  |  |  | #include "core/subsurfacestartup.h"
 | 
					
						
							| 
									
										
										
										
											2018-08-14 10:12:32 +02:00
										 |  |  | #include "core/settings/qPref.h"
 | 
					
						
							| 
									
										
										
										
											2018-09-08 19:46:11 +02:00
										 |  |  | #include "core/settings/qPrefDisplay.h"
 | 
					
						
							| 
									
										
										
										
											2019-05-30 18:29:36 +02:00
										 |  |  | #include "core/tag.h"
 | 
					
						
							| 
									
										
										
										
											2013-09-09 05:59:03 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-06-16 06:52:06 -07:00
										 |  |  | #include <QApplication>
 | 
					
						
							| 
									
										
										
										
											2017-12-03 21:04:45 +08:00
										 |  |  | #include <QLocale>
 | 
					
						
							| 
									
										
										
										
											2018-07-25 18:36:40 -07:00
										 |  |  | #include <QLoggingCategory>
 | 
					
						
							|  |  |  | #include <QStringList>
 | 
					
						
							| 
									
										
										
										
											2014-03-31 13:37:41 -07:00
										 |  |  | #include <git2.h>
 | 
					
						
							| 
									
										
										
										
											2013-09-09 05:59:03 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-05-28 16:25:39 +02:00
										 |  |  | // Implementation of STP logging
 | 
					
						
							|  |  |  | #include "core/ssrf.h"
 | 
					
						
							|  |  |  | #ifdef ENABLE_STARTUP_TIMING
 | 
					
						
							|  |  |  | #include <QElapsedTimer>
 | 
					
						
							|  |  |  | #include <QMutex>
 | 
					
						
							|  |  |  | #include <QMutexLocker>
 | 
					
						
							|  |  |  | void log_stp(const char *ident, QString *buf) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	static bool firstCall = true; | 
					
						
							|  |  |  | 	static QElapsedTimer stpDuration; | 
					
						
							|  |  |  | 	static QString stpText; | 
					
						
							|  |  |  | 	static QMutex logMutex; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	QMutexLocker l(&logMutex); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (firstCall) { | 
					
						
							|  |  |  | 		firstCall = false; | 
					
						
							|  |  |  | 		stpDuration.start(); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	if (ident) | 
					
						
							| 
									
										
										
										
											2018-07-25 18:36:40 -07:00
										 |  |  | 		stpText += QString("STP ") | 
					
						
							|  |  |  | 				   .append(QString::number(stpDuration.elapsed())) | 
					
						
							|  |  |  | 				   .append(" ms, ") | 
					
						
							|  |  |  | 				   .append(ident) | 
					
						
							|  |  |  | 				   .append("\n"); | 
					
						
							| 
									
										
										
										
											2018-05-28 16:25:39 +02:00
										 |  |  | 	if (buf) { | 
					
						
							|  |  |  | 		*buf += "---------- startup timer ----------\n"; | 
					
						
							|  |  |  | 		*buf += stpText; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | #endif // ENABLE_STARTUP_TIMING
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-09-09 05:59:03 -03:00
										 |  |  | int main(int argc, char **argv) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2018-05-28 16:25:39 +02:00
										 |  |  | 	LOG_STP("main starting"); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-09-09 05:59:03 -03:00
										 |  |  | 	int i; | 
					
						
							| 
									
										
										
										
											2017-03-31 16:15:14 +02:00
										 |  |  | 	QGuiApplication::setAttribute(Qt::AA_EnableHighDpiScaling); | 
					
						
							| 
									
										
										
										
											2015-07-06 17:11:02 +03:00
										 |  |  | 	QLoggingCategory::setFilterRules(QStringLiteral("qt.bluetooth* = true")); | 
					
						
							| 
									
										
										
										
											2018-05-21 20:57:10 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	// Start application
 | 
					
						
							|  |  |  | 	new QApplication(argc, argv); | 
					
						
							| 
									
										
										
										
											2018-05-28 16:25:39 +02:00
										 |  |  | 	LOG_STP("main Qt started"); | 
					
						
							| 
									
										
										
										
											2018-05-21 20:57:10 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	// and get comand line arguments
 | 
					
						
							| 
									
										
										
										
											2013-10-08 12:48:46 +03:00
										 |  |  | 	QStringList arguments = QCoreApplication::arguments(); | 
					
						
							| 
									
										
										
										
											2014-03-25 16:55:56 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-11-03 01:51:33 +02:00
										 |  |  | 	subsurface_console_init(); | 
					
						
							| 
									
										
										
										
											2014-03-25 16:55:56 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-10-08 12:48:46 +03:00
										 |  |  | 	for (i = 1; i < arguments.length(); i++) { | 
					
						
							|  |  |  | 		QString a = arguments.at(i); | 
					
						
							| 
									
										
										
										
											2016-06-17 04:10:34 -07:00
										 |  |  | 		if (!a.isEmpty() && a.at(0) == '-') { | 
					
						
							| 
									
										
										
										
											2018-02-25 13:51:41 +01:00
										 |  |  | 			parse_argument(qPrintable(a)); | 
					
						
							| 
									
										
										
										
											2013-09-09 05:59:03 -03:00
										 |  |  | 			continue; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2014-12-06 15:49:57 +02:00
										 |  |  | 	git_libgit2_init(); | 
					
						
							| 
									
										
										
										
											2018-05-28 16:25:39 +02:00
										 |  |  | 	LOG_STP("main git loaded"); | 
					
						
							| 
									
										
										
										
											2014-03-19 18:23:43 +02:00
										 |  |  | 	setup_system_prefs(); | 
					
						
							| 
									
										
										
										
											2017-12-03 21:04:45 +08:00
										 |  |  | 	if (QLocale().measurementSystem() == QLocale::MetricSystem) | 
					
						
							|  |  |  | 		default_prefs.units = SI_units; | 
					
						
							|  |  |  | 	else | 
					
						
							| 
									
										
										
										
											2016-01-05 23:43:05 -08:00
										 |  |  | 		default_prefs.units = IMPERIAL_units; | 
					
						
							| 
									
										
										
										
											2017-11-25 09:22:19 +01:00
										 |  |  | 	copy_prefs(&default_prefs, &prefs); | 
					
						
							| 
									
										
										
										
											2017-04-27 20:24:14 +02:00
										 |  |  | 	fill_computer_list(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-03-19 18:23:43 +02:00
										 |  |  | 	parse_xml_init(); | 
					
						
							| 
									
										
										
										
											2018-05-28 16:25:39 +02:00
										 |  |  | 	LOG_STP("main xml parsed"); | 
					
						
							| 
									
										
										
										
											2014-03-19 18:23:43 +02:00
										 |  |  | 	taglist_init_global(); | 
					
						
							| 
									
										
										
										
											2018-05-28 16:25:39 +02:00
										 |  |  | 	LOG_STP("main taglist done"); | 
					
						
							| 
									
										
										
										
											2014-03-19 18:23:43 +02:00
										 |  |  | 	init_ui(); | 
					
						
							| 
									
										
										
										
											2018-05-28 16:25:39 +02:00
										 |  |  | 	LOG_STP("main init_ui done"); | 
					
						
							| 
									
										
										
										
											2016-04-22 06:57:08 -07:00
										 |  |  | 	if (prefs.default_file_behavior == LOCAL_DEFAULT_FILE) | 
					
						
							| 
									
										
										
										
											2017-12-10 22:22:13 +01:00
										 |  |  | 		set_filename(prefs.default_filename); | 
					
						
							| 
									
										
										
										
											2016-04-27 06:01:07 -07:00
										 |  |  | 	else | 
					
						
							| 
									
										
										
										
											2017-12-10 22:22:13 +01:00
										 |  |  | 		set_filename(NULL); | 
					
						
							| 
									
										
										
										
											2016-04-22 06:57:08 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-27 19:18:48 -05:00
										 |  |  | 	// some hard coded settings
 | 
					
						
							| 
									
										
										
										
											2018-08-20 11:51:48 +02:00
										 |  |  | 	qPrefDisplay::set_animation_speed(0); // we render the profile to pixmap, no animations
 | 
					
						
							| 
									
										
										
										
											2016-02-06 08:36:42 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-27 19:18:48 -05:00
										 |  |  | 	// always show the divecomputer reported ceiling in red
 | 
					
						
							| 
									
										
										
										
											2016-02-06 08:36:42 +01:00
										 |  |  | 	prefs.redceiling = 1; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-11-14 09:38:18 -08:00
										 |  |  | 	init_proxy(); | 
					
						
							| 
									
										
										
										
											2015-10-05 23:52:39 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-05-28 16:25:39 +02:00
										 |  |  | 	LOG_STP("main call run_ui (continue in qmlmanager)"); | 
					
						
							| 
									
										
										
										
											2013-11-02 12:00:16 -07:00
										 |  |  | 	if (!quit) | 
					
						
							|  |  |  | 		run_ui(); | 
					
						
							| 
									
										
										
										
											2013-09-09 05:59:03 -03:00
										 |  |  | 	exit_ui(); | 
					
						
							| 
									
										
										
										
											2014-12-18 08:47:55 +01:00
										 |  |  | 	taglist_free(g_tag_list); | 
					
						
							| 
									
										
										
										
											2014-03-19 18:23:43 +02:00
										 |  |  | 	parse_xml_exit(); | 
					
						
							| 
									
										
										
										
											2014-03-25 16:55:56 +02:00
										 |  |  | 	subsurface_console_exit(); | 
					
						
							| 
									
										
										
										
											2018-08-14 10:12:32 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	// Sync struct preferences to disk
 | 
					
						
							|  |  |  | 	qPref::sync(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-12-18 08:47:42 +01:00
										 |  |  | 	free_prefs(); | 
					
						
							| 
									
										
										
										
											2013-09-09 05:59:03 -03:00
										 |  |  | 	return 0; | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2018-07-11 12:54:00 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-25 18:36:40 -07:00
										 |  |  | void set_non_bt_addresses() | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2018-07-11 12:54:00 +02:00
										 |  |  | #if defined(Q_OS_ANDROID)
 | 
					
						
							|  |  |  | 	connectionListModel.addAddress("FTDI"); | 
					
						
							|  |  |  | #elif defined(Q_OS_LINUX) // since this is in the else, it does NOT include Android
 | 
					
						
							|  |  |  | 	connectionListModel.addAddress("/dev/ttyS0"); | 
					
						
							|  |  |  | 	connectionListModel.addAddress("/dev/ttyS1"); | 
					
						
							|  |  |  | 	connectionListModel.addAddress("/dev/ttyS2"); | 
					
						
							|  |  |  | 	connectionListModel.addAddress("/dev/ttyS3"); | 
					
						
							|  |  |  | 	// this makes debugging so much easier - use the simulator
 | 
					
						
							|  |  |  | 	connectionListModel.addAddress("/tmp/ttyS1"); | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | bool haveFilesOnCommandLine() | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	return false; | 
					
						
							|  |  |  | } |