move env cleaning and clean before java test
This commit is contained in:
parent
9d3a847555
commit
48274e889f
@ -1,4 +1,5 @@
|
|||||||
#include "JavaChecker.h"
|
#include "JavaChecker.h"
|
||||||
|
#include "JavaUtils.h"
|
||||||
#include <FileSystem.h>
|
#include <FileSystem.h>
|
||||||
#include <Commandline.h>
|
#include <Commandline.h>
|
||||||
#include <QFile>
|
#include <QFile>
|
||||||
@ -42,6 +43,7 @@ void JavaChecker::performCheck()
|
|||||||
process->setArguments(args);
|
process->setArguments(args);
|
||||||
process->setProgram(m_path);
|
process->setProgram(m_path);
|
||||||
process->setProcessChannelMode(QProcess::SeparateChannels);
|
process->setProcessChannelMode(QProcess::SeparateChannels);
|
||||||
|
process->setProcessEnvironment(CleanEnviroment());
|
||||||
qDebug() << "Running java checker: " + m_path + args.join(" ");;
|
qDebug() << "Running java checker: " + m_path + args.join(" ");;
|
||||||
|
|
||||||
connect(process.get(), SIGNAL(finished(int, QProcess::ExitStatus)), this, SLOT(finished(int, QProcess::ExitStatus)));
|
connect(process.get(), SIGNAL(finished(int, QProcess::ExitStatus)), this, SLOT(finished(int, QProcess::ExitStatus)));
|
||||||
|
@ -25,10 +25,102 @@
|
|||||||
#include "java/JavaInstallList.h"
|
#include "java/JavaInstallList.h"
|
||||||
#include "FileSystem.h"
|
#include "FileSystem.h"
|
||||||
|
|
||||||
|
#define IBUS "@im=ibus"
|
||||||
|
|
||||||
JavaUtils::JavaUtils()
|
JavaUtils::JavaUtils()
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static QString processLD_LIBRARY_PATH(const QString & LD_LIBRARY_PATH)
|
||||||
|
{
|
||||||
|
QDir mmcBin(QCoreApplication::applicationDirPath());
|
||||||
|
auto items = LD_LIBRARY_PATH.split(':');
|
||||||
|
QStringList final;
|
||||||
|
for(auto & item: items)
|
||||||
|
{
|
||||||
|
QDir test(item);
|
||||||
|
if(test == mmcBin)
|
||||||
|
{
|
||||||
|
qDebug() << "Env:LD_LIBRARY_PATH ignoring path" << item;
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
final.append(item);
|
||||||
|
}
|
||||||
|
return final.join(':');
|
||||||
|
}
|
||||||
|
|
||||||
|
QProcessEnvironment CleanEnviroment()
|
||||||
|
{
|
||||||
|
// prepare the process environment
|
||||||
|
QProcessEnvironment rawenv = QProcessEnvironment::systemEnvironment();
|
||||||
|
QProcessEnvironment env;
|
||||||
|
|
||||||
|
QStringList ignored =
|
||||||
|
{
|
||||||
|
"JAVA_ARGS",
|
||||||
|
"CLASSPATH",
|
||||||
|
"CONFIGPATH",
|
||||||
|
"JAVA_HOME",
|
||||||
|
"JRE_HOME",
|
||||||
|
"_JAVA_OPTIONS",
|
||||||
|
"JAVA_OPTIONS",
|
||||||
|
"JAVA_TOOL_OPTIONS"
|
||||||
|
};
|
||||||
|
for(auto key: rawenv.keys())
|
||||||
|
{
|
||||||
|
auto value = rawenv.value(key);
|
||||||
|
// filter out dangerous java crap
|
||||||
|
if(ignored.contains(key))
|
||||||
|
{
|
||||||
|
qDebug() << "Env: ignoring" << key << value;
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
// filter MultiMC-related things
|
||||||
|
if(key.startsWith("QT_"))
|
||||||
|
{
|
||||||
|
qDebug() << "Env: ignoring" << key << value;
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
#ifdef Q_OS_LINUX
|
||||||
|
// Do not pass LD_* variables to java. They were intended for MultiMC
|
||||||
|
if(key.startsWith("LD_"))
|
||||||
|
{
|
||||||
|
qDebug() << "Env: ignoring" << key << value;
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
// Strip IBus
|
||||||
|
// IBus is a Linux IME framework. For some reason, it breaks MC?
|
||||||
|
if (key == "XMODIFIERS" && value.contains(IBUS))
|
||||||
|
{
|
||||||
|
QString save = value;
|
||||||
|
value.replace(IBUS, "");
|
||||||
|
qDebug() << "Env: stripped" << IBUS << "from" << save << ":" << value;
|
||||||
|
}
|
||||||
|
if(key == "GAME_PRELOAD")
|
||||||
|
{
|
||||||
|
env.insert("LD_PRELOAD", value);
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
if(key == "GAME_LIBRARY_PATH")
|
||||||
|
{
|
||||||
|
env.insert("LD_LIBRARY_PATH", processLD_LIBRARY_PATH(value));
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
qDebug() << "Env: " << key << value;
|
||||||
|
env.insert(key, value);
|
||||||
|
}
|
||||||
|
#ifdef Q_OS_LINUX
|
||||||
|
// HACK: Workaround for QTBUG42500
|
||||||
|
if(!env.contains("LD_LIBRARY_PATH"))
|
||||||
|
{
|
||||||
|
env.insert("LD_LIBRARY_PATH", "");
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
return env;
|
||||||
|
}
|
||||||
|
|
||||||
JavaInstallPtr JavaUtils::MakeJavaPtr(QString path, QString id, QString arch)
|
JavaInstallPtr JavaUtils::MakeJavaPtr(QString path, QString id, QString arch)
|
||||||
{
|
{
|
||||||
JavaInstallPtr javaVersion(new JavaInstall());
|
JavaInstallPtr javaVersion(new JavaInstall());
|
||||||
|
@ -26,6 +26,8 @@
|
|||||||
|
|
||||||
#include "multimc_logic_export.h"
|
#include "multimc_logic_export.h"
|
||||||
|
|
||||||
|
QProcessEnvironment CleanEnviroment();
|
||||||
|
|
||||||
class MULTIMC_LOGIC_EXPORT JavaUtils : public QObject
|
class MULTIMC_LOGIC_EXPORT JavaUtils : public QObject
|
||||||
{
|
{
|
||||||
Q_OBJECT
|
Q_OBJECT
|
||||||
|
@ -20,6 +20,7 @@
|
|||||||
#include "minecraft/launch/ModMinecraftJar.h"
|
#include "minecraft/launch/ModMinecraftJar.h"
|
||||||
#include "minecraft/launch/ClaimAccount.h"
|
#include "minecraft/launch/ClaimAccount.h"
|
||||||
#include "java/launch/CheckJava.h"
|
#include "java/launch/CheckJava.h"
|
||||||
|
#include "java/JavaUtils.h"
|
||||||
#include <meta/Index.h>
|
#include <meta/Index.h>
|
||||||
#include <meta/VersionList.h>
|
#include <meta/VersionList.h>
|
||||||
|
|
||||||
@ -181,71 +182,7 @@ static QString processLD_LIBRARY_PATH(const QString & LD_LIBRARY_PATH)
|
|||||||
QProcessEnvironment MinecraftInstance::createEnvironment()
|
QProcessEnvironment MinecraftInstance::createEnvironment()
|
||||||
{
|
{
|
||||||
// prepare the process environment
|
// prepare the process environment
|
||||||
QProcessEnvironment rawenv = QProcessEnvironment::systemEnvironment();
|
QProcessEnvironment env = CleanEnviroment();
|
||||||
QProcessEnvironment env;
|
|
||||||
|
|
||||||
QStringList ignored =
|
|
||||||
{
|
|
||||||
"JAVA_ARGS",
|
|
||||||
"CLASSPATH",
|
|
||||||
"CONFIGPATH",
|
|
||||||
"JAVA_HOME",
|
|
||||||
"JRE_HOME",
|
|
||||||
"_JAVA_OPTIONS",
|
|
||||||
"JAVA_OPTIONS",
|
|
||||||
"JAVA_TOOL_OPTIONS"
|
|
||||||
};
|
|
||||||
for(auto key: rawenv.keys())
|
|
||||||
{
|
|
||||||
auto value = rawenv.value(key);
|
|
||||||
// filter out dangerous java crap
|
|
||||||
if(ignored.contains(key))
|
|
||||||
{
|
|
||||||
qDebug() << "Env: ignoring" << key << value;
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
// filter MultiMC-related things
|
|
||||||
if(key.startsWith("QT_"))
|
|
||||||
{
|
|
||||||
qDebug() << "Env: ignoring" << key << value;
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
#ifdef Q_OS_LINUX
|
|
||||||
// Do not pass LD_* variables to java. They were intended for MultiMC
|
|
||||||
if(key.startsWith("LD_"))
|
|
||||||
{
|
|
||||||
qDebug() << "Env: ignoring" << key << value;
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
// Strip IBus
|
|
||||||
// IBus is a Linux IME framework. For some reason, it breaks MC?
|
|
||||||
if (key == "XMODIFIERS" && value.contains(IBUS))
|
|
||||||
{
|
|
||||||
QString save = value;
|
|
||||||
value.replace(IBUS, "");
|
|
||||||
qDebug() << "Env: stripped" << IBUS << "from" << save << ":" << value;
|
|
||||||
}
|
|
||||||
if(key == "GAME_PRELOAD")
|
|
||||||
{
|
|
||||||
env.insert("LD_PRELOAD", value);
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
if(key == "GAME_LIBRARY_PATH")
|
|
||||||
{
|
|
||||||
env.insert("LD_LIBRARY_PATH", processLD_LIBRARY_PATH(value));
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
qDebug() << "Env: " << key << value;
|
|
||||||
env.insert(key, value);
|
|
||||||
}
|
|
||||||
#ifdef Q_OS_LINUX
|
|
||||||
// HACK: Workaround for QTBUG42500
|
|
||||||
if(!env.contains("LD_LIBRARY_PATH"))
|
|
||||||
{
|
|
||||||
env.insert("LD_LIBRARY_PATH", "");
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
// export some infos
|
// export some infos
|
||||||
auto variables = getVariables();
|
auto variables = getVariables();
|
||||||
|
Loading…
x
Reference in New Issue
Block a user