WIP CLIparser #25
							
								
								
									
										30
									
								
								main.cpp
									
									
									
									
									
								
							
							
						
						
									
										30
									
								
								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>
 | 
				
			||||||
@@ -32,7 +33,15 @@ int main(int argc, char *argv[])
 | 
				
			|||||||
	QDir dir;
 | 
						QDir dir;
 | 
				
			||||||
	if(argc >= 2)
 | 
						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))
 | 
							if(!dir.exists(configDirectoryPath))
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
			QMessageBox::warning(nullptr, "Directory not found", configDirectoryPath + " was not found");
 | 
								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/";
 | 
							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
 | 
						// TODO if setting single instance mode
 | 
				
			||||||
	QLocalSocket localSocket;
 | 
						QLocalSocket localSocket;
 | 
				
			||||||
	localSocket.connectToServer("/tmp/qsrun.socket");
 | 
						localSocket.connectToServer("/tmp/qsrun.socket");
 | 
				
			||||||
	SingleInstanceServer server;
 | 
						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();
 | 
				
			||||||
@@ -78,8 +87,8 @@ int main(int argc, char *argv[])
 | 
				
			|||||||
		{
 | 
							{
 | 
				
			||||||
			qDebug() << "Failed to listen on socket!";
 | 
								qDebug() << "Failed to listen on socket!";
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
		Window *w = new Window { entryProvider, settingsProvider };
 | 
							Window *w = new Window{entryProvider, settingsProvider};
 | 
				
			||||||
		QObject::connect(&server, &SingleInstanceServer::receivedMaximizationRequest, [&w]{
 | 
							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";
 | 
				
			||||||
@@ -91,10 +100,7 @@ int main(int argc, char *argv[])
 | 
				
			|||||||
		});
 | 
							});
 | 
				
			||||||
		w->showMaximized();
 | 
							w->showMaximized();
 | 
				
			||||||
		w->focusInput();
 | 
							w->focusInput();
 | 
				
			||||||
 | 
					 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	return app.exec();
 | 
						return app.exec();
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 
 | 
				
			|||||||
		在新工单中引用
	
	屏蔽一个用户