如何将当前进程的命令行参数传递给QProcess
,理想情况下避免任何转换?即无论如何"垃圾"传递给当前进程应该传递给子进程,而不会导致char*
,wchar_t
和QString
之间的转换失效。
问题的动机是this answer。
答案 0 :(得分:2)
GetCommandLine()
返回的本机命令行是一个以可执行文件名/路径开头的wchar_t
数组。 QProcess
在Windows上具有setNativeArguments
方法,该方法可用于附加命令行的参数部分。然后主要工作是parse the command line以找到参数的开头:
QString getWindowsCommandLineArguments() {
const wchar_t *args = GetCommandLine();
bool oddBackslash = false, quoted = false, whitespace = false;
// skip the executable name according to Windows command line parsing rules
while (auto c = *args) {
if (c == L'\\')
oddBackslash ^= 1;
else if (c == L'"')
quoted ^= !oddBackslash;
else if (c == L' ' || c == L'\t')
whitespace = !quoted;
else if (whitespace)
break;
else
oddBackslash = false;
args++;
}
return QString::fromRawData(reinterpret_cast<const QChar*>(args), lstrlen(args));
}
然后:
QProcess process;
process.setNativeArguments(getWindowsCommandLineArguments());
其他平台上没有setNativeArguments
的等价物,因此我们能做的最好的事情是通过QString
往返传递参数。只要参数在当前的8位编码中有效,这将正常工作。必须在main
的开头捕获参数,因为Qt可能会删除它自己解释的参数:
QStringList &setProcessArguments() {
static QStringList args;
return args;
}
const QStringList &processArguments() { return setProcessArguments(); }
int main(int argc, char **argv) {
setProcessArguments().reserve(argc-1);
for (int i = 1; i < argc; ++i)
setProcessArguments().append(QString::fromLocal8Bit(argv[i]));
QCoreApplication app{argc, argv}; // may modify argc, argv
...
}
QProcess process;
process.setArguments(processArguments());