WIP CLIparser #25
							
								
								
									
										73
									
								
								main.cpp
									
									
									
									
									
								
							
							
						
						
									
										73
									
								
								main.cpp
									
									
									
									
									
								
							@@ -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,76 @@ 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"},
 | 
				
			||||||
 | 
								{"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
 | 
					
 | 
				
			||||||
	QLocalSocket localSocket;
 | 
						SingleInstanceServer *server = nullptr;
 | 
				
			||||||
	localSocket.connectToServer("/tmp/qsrun.socket");
 | 
					
 | 
				
			||||||
	SingleInstanceServer server;
 | 
						bool singleInstanceMode = !newInstanceRequested && settingsProvider.singleInstanceMode();
 | 
				
			||||||
	if(localSocket.isOpen() && localSocket.isWritable())
 | 
						if(singleInstanceMode)
 | 
				
			||||||
	{
 | 
						{
 | 
				
			||||||
		QDataStream stream(&localSocket);
 | 
							QLocalSocket localSocket;
 | 
				
			||||||
		stream << (int)0x01; //maximize
 | 
							localSocket.connectToServer(settingsProvider.socketPath());
 | 
				
			||||||
		localSocket.flush();
 | 
							if(localSocket.isOpen() && localSocket.isWritable())
 | 
				
			||||||
		localSocket.waitForBytesWritten();
 | 
							{
 | 
				
			||||||
		localSocket.disconnectFromServer();
 | 
								QDataStream stream(&localSocket);
 | 
				
			||||||
		return 0;
 | 
								stream << (int)0x01; // maximize
 | 
				
			||||||
	}
 | 
								localSocket.flush();
 | 
				
			||||||
	else
 | 
								localSocket.waitForBytesWritten();
 | 
				
			||||||
	{
 | 
								localSocket.disconnectFromServer();
 | 
				
			||||||
		if(!server.listen("/tmp/qsrun.socket"))
 | 
								return 0;
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							server = new SingleInstanceServer();
 | 
				
			||||||
 | 
							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 +110,10 @@ int main(int argc, char *argv[])
 | 
				
			|||||||
				w->focusInput();
 | 
									w->focusInput();
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
		});
 | 
							});
 | 
				
			||||||
		w->showMaximized();
 | 
					 | 
				
			||||||
		w->focusInput();
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						w->showMaximized();
 | 
				
			||||||
 | 
						w->focusInput();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	return app.exec();
 | 
						return app.exec();
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -33,3 +33,8 @@ QString SettingsProvider::getTerminalCommand() const
 | 
				
			|||||||
{
 | 
					{
 | 
				
			||||||
	return settings->value("terminal", "/usr/bin/x-terminal-emulator -e %c").toString();
 | 
						return settings->value("terminal", "/usr/bin/x-terminal-emulator -e %c").toString();
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					QString SettingsProvider::socketPath() const
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
						return settings->value("singleInstanceSocket", "/tmp/qsrun").toString();
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -16,6 +16,7 @@ class SettingsProvider
 | 
				
			|||||||
	virtual int getMaxCols() const;
 | 
						virtual int getMaxCols() const;
 | 
				
			||||||
	virtual bool singleInstanceMode() const;
 | 
						virtual bool singleInstanceMode() const;
 | 
				
			||||||
	QString getTerminalCommand() const;
 | 
						QString getTerminalCommand() const;
 | 
				
			||||||
 | 
						QString socketPath() const;
 | 
				
			||||||
};
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#endif // SETTINGSPROVIDER_H
 | 
					#endif // SETTINGSPROVIDER_H
 | 
				
			||||||
 
 | 
				
			|||||||
		Reference in New Issue
	
	Block a user