From 883b71e8a821efa921c26daf1b8285a52199bc3a Mon Sep 17 00:00:00 2001 From: Albert S Date: Thu, 8 Oct 2020 23:08:16 +0200 Subject: [PATCH] Parse argv using QCommandLineParser Fixes: #17 --- main.cpp | 30 ++++++++++++++++++------------ 1 file changed, 18 insertions(+), 12 deletions(-) diff --git a/main.cpp b/main.cpp index 691ea60..62b728c 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 @@ -32,7 +33,15 @@ int main(int argc, char *argv[]) QDir dir; if(argc >= 2) { - configDirectoryPath = QCoreApplication::arguments().at(1); + QCommandLineParser parser; + 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"); if(!dir.exists(configDirectoryPath)) { QMessageBox::warning(nullptr, "Directory not found", configDirectoryPath + " was not found"); @@ -43,30 +52,30 @@ int main(int argc, char *argv[]) { 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 + // TODO if setting single instance mode QLocalSocket localSocket; localSocket.connectToServer("/tmp/qsrun.socket"); SingleInstanceServer server; if(localSocket.isOpen() && localSocket.isWritable()) { QDataStream stream(&localSocket); - stream << (int)0x01; //maximize + stream << (int)0x01; // maximize localSocket.flush(); localSocket.waitForBytesWritten(); localSocket.disconnectFromServer(); @@ -78,8 +87,8 @@ int main(int argc, char *argv[]) { qDebug() << "Failed to listen on socket!"; } - Window *w = new Window { entryProvider, settingsProvider }; - QObject::connect(&server, &SingleInstanceServer::receivedMaximizationRequest, [&w]{ + Window *w = new Window{entryProvider, settingsProvider}; + QObject::connect(&server, &SingleInstanceServer::receivedMaximizationRequest, [&w] { if(w != nullptr) { qInfo() << "maximizing as requested by other instance"; @@ -91,10 +100,7 @@ int main(int argc, char *argv[]) }); w->showMaximized(); w->focusInput(); - } - - return app.exec(); }