WIP CLIparser #25
							
								
								
									
										73
									
								
								main.cpp
									
									
									
									
									
								
							
							
						
						
									
										73
									
								
								main.cpp
									
									
									
									
									
								
							@@ -14,6 +14,7 @@
 | 
			
		||||
 * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
 | 
			
		||||
 */
 | 
			
		||||
#include <QApplication>
 | 
			
		||||
#include <QCommandLineParser>
 | 
			
		||||
#include <QFuture>
 | 
			
		||||
#include <QFutureWatcher>
 | 
			
		||||
#include <QtConcurrent/QtConcurrentRun>
 | 
			
		||||
@@ -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<QString> >("QVector<QString>");
 | 
			
		||||
 | 
			
		||||
	qRegisterMetaType<QVector<QString>>("QVector<QString>");
 | 
			
		||||
 | 
			
		||||
	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();
 | 
			
		||||
}
 | 
			
		||||
 
 | 
			
		||||
@@ -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();
 | 
			
		||||
}
 | 
			
		||||
 
 | 
			
		||||
@@ -16,6 +16,7 @@ class SettingsProvider
 | 
			
		||||
	virtual int getMaxCols() const;
 | 
			
		||||
	virtual bool singleInstanceMode() const;
 | 
			
		||||
	QString getTerminalCommand() const;
 | 
			
		||||
	QString socketPath() const;
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
#endif // SETTINGSPROVIDER_H
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user