2015-04-16 11:50:07 -05:00
|
|
|
/*
|
|
|
|
Copyright (C) 2010 Srivats P.
|
|
|
|
|
|
|
|
This file is part of "Ostinato"
|
|
|
|
|
|
|
|
This 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, either 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 for more details.
|
|
|
|
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
|
|
along with this program. If not, see <http://www.gnu.org/licenses/>
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include "drone.h"
|
|
|
|
|
|
|
|
#include "../common/protocolmanager.h"
|
2019-07-02 07:45:26 -05:00
|
|
|
#include "params.h"
|
2015-04-16 11:50:07 -05:00
|
|
|
#include "settings.h"
|
2021-03-28 02:12:53 -05:00
|
|
|
#include "turbo.h"
|
2015-04-16 11:50:07 -05:00
|
|
|
|
|
|
|
#include <google/protobuf/stubs/common.h>
|
|
|
|
|
|
|
|
#include <QCoreApplication>
|
|
|
|
#include <QFile>
|
|
|
|
|
|
|
|
#include <signal.h>
|
|
|
|
|
|
|
|
extern ProtocolManager *OstProtocolManager;
|
|
|
|
extern char *version;
|
|
|
|
extern char *revision;
|
|
|
|
|
2015-11-10 08:10:32 -06:00
|
|
|
Drone *drone;
|
2015-04-16 11:50:07 -05:00
|
|
|
QSettings *appSettings;
|
2019-07-02 07:45:26 -05:00
|
|
|
Params appParams;
|
|
|
|
|
|
|
|
void NoMsgHandler(QtMsgType type, const QMessageLogContext &context,
|
|
|
|
const QString &msg);
|
2015-04-16 11:50:07 -05:00
|
|
|
|
|
|
|
void cleanup(int /*signum*/)
|
|
|
|
{
|
2021-07-07 10:14:46 -05:00
|
|
|
fprintf(stderr, "\nCleaning up (may take a few seconds) ... ");
|
2021-03-28 02:20:29 -05:00
|
|
|
fflush(stderr);
|
2015-04-16 11:50:07 -05:00
|
|
|
QCoreApplication::instance()->exit(-1);
|
|
|
|
}
|
|
|
|
|
|
|
|
int main(int argc, char *argv[])
|
|
|
|
{
|
|
|
|
int exitCode = 0;
|
|
|
|
QCoreApplication app(argc, argv);
|
|
|
|
|
|
|
|
app.setApplicationName("Drone");
|
|
|
|
app.setOrganizationName("Ostinato");
|
|
|
|
|
2019-07-02 07:45:26 -05:00
|
|
|
appParams.parseCommandLine(argc, argv);
|
|
|
|
|
2021-04-03 01:30:07 -05:00
|
|
|
fprintf(stderr, "Starting (will take a few seconds) ...\n");
|
|
|
|
fflush(stderr);
|
|
|
|
|
2019-07-02 07:45:26 -05:00
|
|
|
#ifdef QT_NO_DEBUG
|
|
|
|
if (appParams.optLogsDisabled())
|
|
|
|
qInstallMessageHandler(NoMsgHandler);
|
|
|
|
#endif
|
|
|
|
|
|
|
|
qDebug("Version: %s", version);
|
|
|
|
qDebug("Revision: %s", revision);
|
|
|
|
|
2015-04-16 11:50:07 -05:00
|
|
|
/* (Portable Mode) If we have a .ini file in the same directory as the
|
|
|
|
executable, we use that instead of the platform specific location
|
|
|
|
and format for the settings */
|
|
|
|
QString portableIni = QCoreApplication::applicationDirPath()
|
|
|
|
+ "/drone.ini";
|
|
|
|
if (QFile::exists(portableIni))
|
|
|
|
appSettings = new QSettings(portableIni, QSettings::IniFormat);
|
|
|
|
else
|
|
|
|
appSettings = new QSettings(QSettings::IniFormat,
|
|
|
|
QSettings::UserScope,
|
|
|
|
app.organizationName(),
|
|
|
|
app.applicationName().toLower());
|
2020-05-06 07:22:18 -05:00
|
|
|
qDebug("Settings: %s", qPrintable(appSettings->fileName()));
|
2015-04-16 11:50:07 -05:00
|
|
|
|
2021-07-06 10:39:14 -05:00
|
|
|
if (!initTurbo())
|
|
|
|
{
|
|
|
|
exitCode = 1;
|
|
|
|
goto _exit2;
|
|
|
|
}
|
2021-03-28 02:12:53 -05:00
|
|
|
|
2015-04-16 11:50:07 -05:00
|
|
|
drone = new Drone();
|
|
|
|
OstProtocolManager = new ProtocolManager();
|
|
|
|
|
|
|
|
if (!drone->init())
|
|
|
|
{
|
2017-09-26 09:29:49 -05:00
|
|
|
exitCode = 1;
|
2015-04-16 11:50:07 -05:00
|
|
|
goto _exit;
|
|
|
|
}
|
|
|
|
|
|
|
|
qDebug("Version: %s", version);
|
|
|
|
qDebug("Revision: %s", revision);
|
|
|
|
|
|
|
|
#ifdef Q_OS_UNIX
|
|
|
|
struct sigaction sa;
|
|
|
|
memset(&sa, 0, sizeof(sa));
|
|
|
|
sa.sa_handler = cleanup;
|
|
|
|
if (sigaction(SIGTERM, &sa, NULL))
|
|
|
|
qDebug("Failed to install SIGTERM handler. Cleanup may not happen!!!");
|
|
|
|
if (sigaction(SIGINT, &sa, NULL))
|
|
|
|
qDebug("Failed to install SIGINT handler. Cleanup may not happen!!!");
|
2020-12-27 01:24:57 -06:00
|
|
|
#elif defined(Q_OS_WIN32)
|
|
|
|
if (signal(SIGTERM, cleanup) == SIG_ERR)
|
|
|
|
qDebug("Failed to install SIGTERM handler. Cleanup may not happen!!!");
|
|
|
|
if (signal(SIGINT, cleanup) == SIG_ERR)
|
|
|
|
qDebug("Failed to install SIGINT handler. Cleanup may not happen!!!");
|
2015-04-16 11:50:07 -05:00
|
|
|
#endif
|
|
|
|
|
|
|
|
exitCode = app.exec();
|
|
|
|
|
|
|
|
_exit:
|
|
|
|
delete drone;
|
|
|
|
delete OstProtocolManager;
|
|
|
|
|
2021-07-06 10:39:14 -05:00
|
|
|
_exit2:
|
2015-04-16 11:50:07 -05:00
|
|
|
google::protobuf::ShutdownProtobufLibrary();
|
|
|
|
|
2021-03-28 02:20:29 -05:00
|
|
|
fprintf(stderr, "done.\n");
|
|
|
|
fflush(stderr);
|
|
|
|
|
2015-04-16 11:50:07 -05:00
|
|
|
return exitCode;
|
|
|
|
}
|
|
|
|
|
2019-07-02 07:45:26 -05:00
|
|
|
void NoMsgHandler(QtMsgType type, const QMessageLogContext &/*context*/,
|
|
|
|
const QString &msg)
|
|
|
|
{
|
|
|
|
if (type == QtFatalMsg) {
|
2019-07-02 08:44:38 -05:00
|
|
|
fprintf(stderr, "%s\n", qPrintable(msg));
|
2019-07-02 07:45:26 -05:00
|
|
|
fflush(stderr);
|
|
|
|
abort();
|
|
|
|
}
|
|
|
|
}
|