aboutsummaryrefslogtreecommitdiff
path: root/src/qt/workers.cpp
diff options
context:
space:
mode:
authorJan200101 <sentrycraft123@gmail.com>2022-06-30 19:26:37 +0200
committerJan200101 <sentrycraft123@gmail.com>2022-06-30 19:26:37 +0200
commit4833e4be7e55776a47169cdea926444e1cdeabe6 (patch)
treee24b5e70a961574da28218a499c2f9ec281de6a5 /src/qt/workers.cpp
parentcbf1b717914ca9d3e52d7ceaae153928afcc9eda (diff)
downloadOFQT-4833e4be7e55776a47169cdea926444e1cdeabe6.tar.gz
OFQT-4833e4be7e55776a47169cdea926444e1cdeabe6.zip
add launch options to Qt frontend
Diffstat (limited to 'src/qt/workers.cpp')
-rw-r--r--src/qt/workers.cpp25
1 files changed, 24 insertions, 1 deletions
diff --git a/src/qt/workers.cpp b/src/qt/workers.cpp
index dc761e9..9d5dc37 100644
--- a/src/qt/workers.cpp
+++ b/src/qt/workers.cpp
@@ -86,6 +86,16 @@ void Worker::setRemote(QString remotestr)
setLocalRemote(of_dir, remote);
}
+QString Worker::getArguments()
+{
+ return settings.value("launchArguments", QString()).toString();
+}
+
+void Worker::setArguments(QString argumentstr)
+{
+ settings.setValue("launchArguments", argumentstr);
+}
+
int Worker::getRevision()
{
return getLocalRevision(of_dir);
@@ -309,7 +319,20 @@ void Worker::doWork(const enum Worker::Tasks_t &parameter) {
case TASK_RUN:
result = getSteamPID() > -1 ? RESULT_EXIT : RESULT_NO_STEAM;
- if (result == RESULT_EXIT) runOpenFortress(NULL, 0);
+ if (result == RESULT_EXIT)
+ {
+ auto arg_list = getArguments().split(' ', Qt::SkipEmptyParts);
+
+ auto argv = (char**)malloc(sizeof(char*) * arg_list.size());
+ for (int i = 0; i < arg_list.size(); ++i)
+ argv[i] = strdup(arg_list[i].toStdString().c_str());
+
+ runOpenFortress(argv, arg_list.size());
+
+ for (int i = 0; i < arg_list.size(); ++i)
+ free(argv[i]);
+ free(argv);
+ }
break;
}