GH-2412: collect dead processes on linux properly
Issues were caused by use of `popen()` with no `pclose()` counterpart...
This commit is contained in:
parent
aef0ccb1a2
commit
d5037d4f79
@ -294,7 +294,7 @@ QString NormalizePath(QString path)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
QString badFilenameChars = "\"\\/?<>:*|!";
|
QString badFilenameChars = "\"\\/?<>:*|!+";
|
||||||
|
|
||||||
QString RemoveInvalidFilenameChars(QString string, QChar replaceWith)
|
QString RemoveInvalidFilenameChars(QString string, QChar replaceWith)
|
||||||
{
|
{
|
||||||
|
@ -19,67 +19,88 @@
|
|||||||
#include "PrintInstanceInfo.h"
|
#include "PrintInstanceInfo.h"
|
||||||
#include <launch/LaunchTask.h>
|
#include <launch/LaunchTask.h>
|
||||||
|
|
||||||
void PrintInstanceInfo::executeTask()
|
|
||||||
{
|
|
||||||
auto instance = m_parent->instance();
|
|
||||||
auto lines = instance->verboseDescription(m_session);
|
|
||||||
|
|
||||||
#ifdef Q_OS_LINUX
|
#ifdef Q_OS_LINUX
|
||||||
|
namespace {
|
||||||
|
void probeProcCpuinfo(QStringList &log)
|
||||||
|
{
|
||||||
std::ifstream cpuin("/proc/cpuinfo");
|
std::ifstream cpuin("/proc/cpuinfo");
|
||||||
for (std::string line; std::getline(cpuin, line);)
|
for (std::string line; std::getline(cpuin, line);)
|
||||||
{
|
{
|
||||||
if (strncmp(line.c_str(), "model name", 10) == 0)
|
if (strncmp(line.c_str(), "model name", 10) == 0)
|
||||||
{
|
{
|
||||||
QStringList clines = (QStringList() << QString::fromStdString(line.substr(13, std::string::npos)));
|
log << QString::fromStdString(line.substr(13, std::string::npos));
|
||||||
logLines(clines, MessageLevel::MultiMC);
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void runLspci(QStringList &log)
|
||||||
|
{
|
||||||
|
// FIXME: fixed size buffers...
|
||||||
char buff[512];
|
char buff[512];
|
||||||
int gpuline = -1;
|
int gpuline = -1;
|
||||||
int cline = 0;
|
int cline = 0;
|
||||||
FILE *fp = popen("lspci -k", "r");
|
FILE * lspci = popen("lspci -k", "r");
|
||||||
if (fp != NULL)
|
|
||||||
{
|
|
||||||
while (fgets(buff, 512, fp) != NULL)
|
|
||||||
{
|
|
||||||
std::string str(buff);
|
|
||||||
if (str.length() < 9)
|
|
||||||
continue;
|
|
||||||
if (str.substr(8, 3) == "VGA")
|
|
||||||
{
|
|
||||||
gpuline = cline;
|
|
||||||
QStringList glines = (QStringList() << QString::fromStdString(str.substr(35, std::string::npos)));
|
|
||||||
logLines(glines, MessageLevel::MultiMC);
|
|
||||||
}
|
|
||||||
if (gpuline > -1 && gpuline != cline)
|
|
||||||
{
|
|
||||||
if (cline - gpuline < 3)
|
|
||||||
{
|
|
||||||
QStringList alines = (QStringList() << QString::fromStdString(str.substr(1, std::string::npos)));
|
|
||||||
logLines(alines, MessageLevel::MultiMC);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
cline++;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
FILE *fp2 = popen("glxinfo", "r");
|
if (!lspci)
|
||||||
if (fp2 != NULL)
|
return;
|
||||||
|
|
||||||
|
while (fgets(buff, 512, lspci) != NULL)
|
||||||
{
|
{
|
||||||
while (fgets(buff, 512, fp2) != NULL)
|
std::string str(buff);
|
||||||
|
if (str.length() < 9)
|
||||||
|
continue;
|
||||||
|
if (str.substr(8, 3) == "VGA")
|
||||||
{
|
{
|
||||||
if (strncmp(buff, "OpenGL version string:", 22) == 0)
|
gpuline = cline;
|
||||||
|
log << QString::fromStdString(str.substr(35, std::string::npos));
|
||||||
|
}
|
||||||
|
if (gpuline > -1 && gpuline != cline)
|
||||||
|
{
|
||||||
|
if (cline - gpuline < 3)
|
||||||
{
|
{
|
||||||
QStringList drlines = (QStringList() << QString::fromUtf8(buff));
|
log << QString::fromStdString(str.substr(1, std::string::npos));
|
||||||
logLines(drlines, MessageLevel::MultiMC);
|
|
||||||
break;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
cline++;
|
||||||
}
|
}
|
||||||
|
pclose(lspci);
|
||||||
|
}
|
||||||
|
|
||||||
|
void runGlxinfo(QStringList & log)
|
||||||
|
{
|
||||||
|
// FIXME: fixed size buffers...
|
||||||
|
char buff[512];
|
||||||
|
FILE *glxinfo = popen("glxinfo", "r");
|
||||||
|
if (!glxinfo)
|
||||||
|
return;
|
||||||
|
|
||||||
|
while (fgets(buff, 512, glxinfo) != NULL)
|
||||||
|
{
|
||||||
|
if (strncmp(buff, "OpenGL version string:", 22) == 0)
|
||||||
|
{
|
||||||
|
log << QString::fromUtf8(buff);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
pclose(glxinfo);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
logLines(lines, MessageLevel::MultiMC);
|
void PrintInstanceInfo::executeTask()
|
||||||
|
{
|
||||||
|
auto instance = m_parent->instance();
|
||||||
|
QStringList log;
|
||||||
|
|
||||||
|
#ifdef Q_OS_LINUX
|
||||||
|
::probeProcCpuinfo(log);
|
||||||
|
::runLspci(log);
|
||||||
|
::runGlxinfo(log);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
logLines(log, MessageLevel::MultiMC);
|
||||||
|
logLines(instance->verboseDescription(m_session), MessageLevel::MultiMC);
|
||||||
emitSucceeded();
|
emitSucceeded();
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user