|
|
@ -14,6 +14,7 @@
|
|
|
|
* OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
|
|
|
|
* OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
|
|
|
|
*/
|
|
|
|
*/
|
|
|
|
#include <QApplication>
|
|
|
|
#include <QApplication>
|
|
|
|
|
|
|
|
#include <QCommandLineParser>
|
|
|
|
#include <QFuture>
|
|
|
|
#include <QFuture>
|
|
|
|
#include <QFutureWatcher>
|
|
|
|
#include <QFutureWatcher>
|
|
|
|
#include <QtConcurrent/QtConcurrentRun>
|
|
|
|
#include <QtConcurrent/QtConcurrentRun>
|
|
|
@ -30,56 +31,77 @@ int main(int argc, char *argv[])
|
|
|
|
QApplication app(argc, argv);
|
|
|
|
QApplication app(argc, argv);
|
|
|
|
QString configDirectoryPath;
|
|
|
|
QString configDirectoryPath;
|
|
|
|
QDir dir;
|
|
|
|
QDir dir;
|
|
|
|
|
|
|
|
bool newInstanceRequested = false;
|
|
|
|
if(argc >= 2)
|
|
|
|
if(argc >= 2)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
configDirectoryPath = QCoreApplication::arguments().at(1);
|
|
|
|
QCommandLineParser parser;
|
|
|
|
if(!dir.exists(configDirectoryPath))
|
|
|
|
parser.addOptions({
|
|
|
|
|
|
|
|
{"new-instance", "Launch a new instance, ignoring any running ones"},
|
|
|
|
|
|
|
|
{"kill-instances", "Kill all running instances"},
|
|
|
|
|
|
|
|
{"config", "Use supplied config dir instead of default"},
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
parser.addHelpOption();
|
|
|
|
|
|
|
|
parser.process(app.arguments());
|
|
|
|
|
|
|
|
configDirectoryPath = parser.value("config");
|
|
|
|
|
|
|
|
newInstanceRequested = parser.isSet("new-instance");
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if(!configDirectoryPath.isEmpty() && !dir.exists(configDirectoryPath))
|
|
|
|
{
|
|
|
|
{
|
|
|
|
QMessageBox::warning(nullptr, "Directory not found", configDirectoryPath + " was not found");
|
|
|
|
QMessageBox::warning(nullptr, "Directory not found", configDirectoryPath + " was not found");
|
|
|
|
return 1;
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else
|
|
|
|
if(configDirectoryPath.isEmpty())
|
|
|
|
{
|
|
|
|
{
|
|
|
|
configDirectoryPath = QDir::homePath() + "/.config/qsrun/";
|
|
|
|
configDirectoryPath = QDir::homePath() + "/.config/qsrun/";
|
|
|
|
}
|
|
|
|
}
|
|
|
|
qRegisterMetaType<QVector<QString> >("QVector<QString>");
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
qRegisterMetaType<QVector<QString>>("QVector<QString>");
|
|
|
|
|
|
|
|
|
|
|
|
if(!dir.exists(configDirectoryPath))
|
|
|
|
if(!dir.exists(configDirectoryPath))
|
|
|
|
{
|
|
|
|
{
|
|
|
|
if(!dir.mkdir(configDirectoryPath))
|
|
|
|
if(!dir.mkdir(configDirectoryPath))
|
|
|
|
{
|
|
|
|
{
|
|
|
|
QMessageBox::warning(nullptr, "Failed to create dir", configDirectoryPath + " was not found and could not be created!");
|
|
|
|
QMessageBox::warning(nullptr, "Failed to create dir",
|
|
|
|
|
|
|
|
configDirectoryPath + " was not found and could not be created!");
|
|
|
|
return 1;
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
QSettings settings(configDirectoryPath + "qsrun.config", QSettings::NativeFormat);
|
|
|
|
QSettings settings(configDirectoryPath + "qsrun.config", QSettings::NativeFormat);
|
|
|
|
|
|
|
|
|
|
|
|
SettingsProvider settingsProvider { settings };
|
|
|
|
SettingsProvider settingsProvider{settings};
|
|
|
|
EntryProvider entryProvider(settingsProvider.userEntriesPaths(), settingsProvider.systemApplicationsEntriesPaths());
|
|
|
|
EntryProvider entryProvider(settingsProvider.userEntriesPaths(), settingsProvider.systemApplicationsEntriesPaths());
|
|
|
|
//TODO if setting single instance mode
|
|
|
|
|
|
|
|
|
|
|
|
SingleInstanceServer *server = nullptr;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
bool singleInstanceMode = !newInstanceRequested && settingsProvider.singleInstanceMode();
|
|
|
|
|
|
|
|
if(singleInstanceMode)
|
|
|
|
|
|
|
|
{
|
|
|
|
QLocalSocket localSocket;
|
|
|
|
QLocalSocket localSocket;
|
|
|
|
localSocket.connectToServer("/tmp/qsrun.socket");
|
|
|
|
localSocket.connectToServer(settingsProvider.socketPath());
|
|
|
|
SingleInstanceServer server;
|
|
|
|
|
|
|
|
if(localSocket.isOpen() && localSocket.isWritable())
|
|
|
|
if(localSocket.isOpen() && localSocket.isWritable())
|
|
|
|
{
|
|
|
|
{
|
|
|
|
QDataStream stream(&localSocket);
|
|
|
|
QDataStream stream(&localSocket);
|
|
|
|
stream << (int)0x01; //maximize
|
|
|
|
stream << (int)0x01; // maximize
|
|
|
|
localSocket.flush();
|
|
|
|
localSocket.flush();
|
|
|
|
localSocket.waitForBytesWritten();
|
|
|
|
localSocket.waitForBytesWritten();
|
|
|
|
localSocket.disconnectFromServer();
|
|
|
|
localSocket.disconnectFromServer();
|
|
|
|
return 0;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else
|
|
|
|
|
|
|
|
{
|
|
|
|
server = new SingleInstanceServer();
|
|
|
|
if(!server.listen("/tmp/qsrun.socket"))
|
|
|
|
if(!server->listen(settingsProvider.socketPath()))
|
|
|
|
{
|
|
|
|
{
|
|
|
|
qDebug() << "Failed to listen on socket!";
|
|
|
|
qDebug() << "Failed to listen on socket!";
|
|
|
|
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
Window *w = new Window { entryProvider, settingsProvider };
|
|
|
|
}
|
|
|
|
QObject::connect(&server, &SingleInstanceServer::receivedMaximizationRequest, [&w]{
|
|
|
|
|
|
|
|
|
|
|
|
Window *w = new Window{entryProvider, settingsProvider};
|
|
|
|
|
|
|
|
if(singleInstanceMode && server != nullptr)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
QObject::connect(server, &SingleInstanceServer::receivedMaximizationRequest, [&w] {
|
|
|
|
if(w != nullptr)
|
|
|
|
if(w != nullptr)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
qInfo() << "maximizing as requested by other instance";
|
|
|
|
qInfo() << "maximizing as requested by other instance";
|
|
|
@ -89,12 +111,10 @@ int main(int argc, char *argv[])
|
|
|
|
w->focusInput();
|
|
|
|
w->focusInput();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
w->showMaximized();
|
|
|
|
w->showMaximized();
|
|
|
|
w->focusInput();
|
|
|
|
w->focusInput();
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
return app.exec();
|
|
|
|
return app.exec();
|
|
|
|
}
|
|
|
|
}
|
|
|
|