mirror of
https://gitea.msk.dinamika-avia.ru/Constanta-Design/RRJServer.git
synced 2026-03-27 19:45:43 +03:00
refact. Повторный запуск.
This commit is contained in:
@@ -2,26 +2,40 @@
|
||||
|
||||
#include <QApplication>
|
||||
#include <QTranslator>
|
||||
|
||||
#include "specialmessagebox.h"
|
||||
|
||||
|
||||
bool appIsRunningAlready(QSharedMemory& sharedMemory);
|
||||
QString getLanguageFromSettings();
|
||||
|
||||
|
||||
int main(int argc, char *argv[])
|
||||
{
|
||||
QApplication a(argc, argv);
|
||||
|
||||
|
||||
// Уникальное имя для идентификации процесса
|
||||
const QString sharedMemKey = "ServerMTD_sharedMemKey";
|
||||
// Создание объекта общей памяти
|
||||
QSharedMemory sharedMemory(sharedMemKey);
|
||||
|
||||
if(appIsRunningAlready(sharedMemory))
|
||||
{//Приложение уже запущено
|
||||
return 1;
|
||||
}
|
||||
|
||||
MainWindow w;
|
||||
w.show(); //Закоментировать, если нужно, чтобы по-умолчанию было свернуто в трее!
|
||||
return a.exec();
|
||||
}
|
||||
|
||||
|
||||
bool appIsRunningAlready(QSharedMemory& sharedMemory)
|
||||
{
|
||||
// Попытка прикрепления к существующему сегменту
|
||||
bool isRunningAlready = false;
|
||||
if (sharedMemory.attach(QSharedMemory::ReadWrite))
|
||||
{
|
||||
qWarning() << "App ServerMTD is running already!";
|
||||
qWarning() << "Application is running already!";
|
||||
|
||||
QTranslator qtLanguageTranslator;
|
||||
QString language;
|
||||
@@ -29,29 +43,35 @@ int main(int argc, char *argv[])
|
||||
if(language == "RUS")
|
||||
qtLanguageTranslator.load(QString("translations/RRJServer_") + "ru_RU", ".");
|
||||
qApp->installTranslator(&qtLanguageTranslator);
|
||||
SpecMsgBox::CriticalClose(nullptr, QObject::tr("App ") + QObject::tr("Maintenance training device RRJ-95NEW-100 Server") + QObject::tr(" is running already!"));
|
||||
isRunningAlready = true;
|
||||
} else
|
||||
SpecMsgBox::CriticalClose(nullptr, QObject::tr("Application ") + QObject::tr("Maintenance training device RRJ-95NEW-100 Server") + QObject::tr(" is running already!"));
|
||||
|
||||
return true;
|
||||
}
|
||||
else
|
||||
{
|
||||
// Приложения ещё нет, создаём сегмент памяти
|
||||
if (!sharedMemory.create(1))
|
||||
{
|
||||
qCritical() << "Error create shared memory!";
|
||||
return 1;
|
||||
qCritical() << "Application launch error! Error create shared memory.";
|
||||
|
||||
QTranslator qtLanguageTranslator;
|
||||
QString language;
|
||||
language = getLanguageFromSettings();
|
||||
if(language == "RUS")
|
||||
qtLanguageTranslator.load(QString("translations/RRJServer_") + "ru_RU", ".");
|
||||
qApp->installTranslator(&qtLanguageTranslator);
|
||||
SpecMsgBox::CriticalClose(nullptr, QObject::tr("Application ") + QObject::tr("Maintenance training device RRJ-95NEW-100 Server") + QObject::tr(" launch error! ") + QObject::tr(" Error create shared memory.") +
|
||||
QObject::tr(" Contact your system administrator."));
|
||||
|
||||
return true;
|
||||
}
|
||||
}
|
||||
|
||||
if (isRunningAlready)
|
||||
return 1;
|
||||
|
||||
// Освобождаем общую память при завершении работы приложения
|
||||
QObject::connect(qApp, &QCoreApplication::aboutToQuit,
|
||||
[&]() { sharedMemory.detach(); });
|
||||
|
||||
|
||||
MainWindow w;
|
||||
w.show(); //Закоментировать, если нужно, чтобы по-умолчанию было свернуто в трее!
|
||||
return a.exec();
|
||||
return false;
|
||||
}
|
||||
|
||||
QString getLanguageFromSettings()
|
||||
@@ -62,13 +82,14 @@ QString getLanguageFromSettings()
|
||||
|
||||
QXmlStreamReader xmlReader(&file);
|
||||
|
||||
while (!xmlReader.atEnd()){
|
||||
|
||||
if(xmlReader.isStartElement()){
|
||||
|
||||
while (!xmlReader.atEnd())
|
||||
{
|
||||
if(xmlReader.isStartElement())
|
||||
{
|
||||
if(xmlReader.name() == "DataBaseSettings")
|
||||
{
|
||||
foreach(const QXmlStreamAttribute &attr, xmlReader.attributes()){
|
||||
foreach(const QXmlStreamAttribute &attr, xmlReader.attributes())
|
||||
{
|
||||
QString name = attr.name().toString();
|
||||
QString value = attr.value().toString();
|
||||
|
||||
@@ -80,11 +101,8 @@ QString getLanguageFromSettings()
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
xmlReader.readNext();
|
||||
}
|
||||
|
||||
file.close();
|
||||
|
||||
return "";
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user