diff --git a/main.cpp b/main.cpp index 691ea60..0e7f8f6 100644 --- a/main.cpp +++ b/main.cpp @@ -14,6 +14,7 @@ * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. */ #include +#include #include #include #include @@ -30,56 +31,76 @@ int main(int argc, char *argv[]) QApplication app(argc, argv); QString configDirectoryPath; QDir dir; + bool newInstanceRequested = false; if(argc >= 2) { - configDirectoryPath = QCoreApplication::arguments().at(1); - if(!dir.exists(configDirectoryPath)) + QCommandLineParser parser; + parser.addOptions({ + {"new-instance", "Launch a new instance, ignoring any running ones"}, + {"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"); return 1; } } - else + if(configDirectoryPath.isEmpty()) { configDirectoryPath = QDir::homePath() + "/.config/qsrun/"; } - qRegisterMetaType >("QVector"); + qRegisterMetaType>("QVector"); if(!dir.exists(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; } } QSettings settings(configDirectoryPath + "qsrun.config", QSettings::NativeFormat); - SettingsProvider settingsProvider { settings }; + SettingsProvider settingsProvider{settings}; EntryProvider entryProvider(settingsProvider.userEntriesPaths(), settingsProvider.systemApplicationsEntriesPaths()); - //TODO if setting single instance mode - QLocalSocket localSocket; - localSocket.connectToServer("/tmp/qsrun.socket"); - SingleInstanceServer server; - if(localSocket.isOpen() && localSocket.isWritable()) + + SingleInstanceServer *server = nullptr; + + bool singleInstanceMode = !newInstanceRequested && settingsProvider.singleInstanceMode(); + if(singleInstanceMode) { - QDataStream stream(&localSocket); - stream << (int)0x01; //maximize - localSocket.flush(); - localSocket.waitForBytesWritten(); - localSocket.disconnectFromServer(); - return 0; - } - else - { - if(!server.listen("/tmp/qsrun.socket")) + QLocalSocket localSocket; + localSocket.connectToServer(settingsProvider.socketPath()); + if(localSocket.isOpen() && localSocket.isWritable()) + { + QDataStream stream(&localSocket); + stream << (int)0x01; // maximize + localSocket.flush(); + localSocket.waitForBytesWritten(); + localSocket.disconnectFromServer(); + return 0; + } + + server = new SingleInstanceServer(); + if(!server->listen(settingsProvider.socketPath())) { 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) { qInfo() << "maximizing as requested by other instance"; @@ -89,12 +110,10 @@ int main(int argc, char *argv[]) w->focusInput(); } }); - w->showMaximized(); - w->focusInput(); - } - + w->showMaximized(); + w->focusInput(); return app.exec(); } diff --git a/settingsprovider.cpp b/settingsprovider.cpp index 1b7368d..1089d0c 100644 --- a/settingsprovider.cpp +++ b/settingsprovider.cpp @@ -33,3 +33,8 @@ QString SettingsProvider::getTerminalCommand() const { return settings->value("terminal", "/usr/bin/x-terminal-emulator -e %c").toString(); } + +QString SettingsProvider::socketPath() const +{ + return settings->value("singleInstanceSocket", "/tmp/qsrun").toString(); +} diff --git a/settingsprovider.h b/settingsprovider.h index 48e3ea5..99ad897 100644 --- a/settingsprovider.h +++ b/settingsprovider.h @@ -16,6 +16,7 @@ class SettingsProvider virtual int getMaxCols() const; virtual bool singleInstanceMode() const; QString getTerminalCommand() const; + QString socketPath() const; }; #endif // SETTINGSPROVIDER_H