diff options
author | Petr Mrázek <peterix@gmail.com> | 2015-05-04 01:20:48 +0200 |
---|---|---|
committer | Petr Mrázek <peterix@gmail.com> | 2015-05-04 01:20:48 +0200 |
commit | 1b884d0a9dc28d8bca38fe8756482d991d0ea850 (patch) | |
tree | fabe4350a3d64123ad0801fe7c285c2150f9562b /application/JavaCommon.cpp | |
parent | 8e9d5f56b592fd0dd0f54e747a835391a775120d (diff) | |
download | MultiMC-1b884d0a9dc28d8bca38fe8756482d991d0ea850.tar MultiMC-1b884d0a9dc28d8bca38fe8756482d991d0ea850.tar.gz MultiMC-1b884d0a9dc28d8bca38fe8756482d991d0ea850.tar.lz MultiMC-1b884d0a9dc28d8bca38fe8756482d991d0ea850.tar.xz MultiMC-1b884d0a9dc28d8bca38fe8756482d991d0ea850.zip |
GH-907 improve Java testing and PermGen deprecation handling
Diffstat (limited to 'application/JavaCommon.cpp')
-rw-r--r-- | application/JavaCommon.cpp | 107 |
1 files changed, 107 insertions, 0 deletions
diff --git a/application/JavaCommon.cpp b/application/JavaCommon.cpp new file mode 100644 index 00000000..d0a3cba3 --- /dev/null +++ b/application/JavaCommon.cpp @@ -0,0 +1,107 @@ +#include "JavaCommon.h" +#include "dialogs/CustomMessageBox.h" +#include <MMCStrings.h> + +bool JavaCommon::checkJVMArgs(QString jvmargs, QWidget *parent) +{ + if (jvmargs.contains("-XX:PermSize=") || jvmargs.contains(QRegExp("-Xm[sx]"))) + { + CustomMessageBox::selectable( + parent, QObject::tr("JVM arguments warning"), + QObject::tr("You tried to manually set a JVM memory option (using " + " \"-XX:PermSize\", \"-Xmx\" or \"-Xms\") - there" + " are dedicated boxes for these in the settings (Java" + " tab, in the Memory group at the top).\n" + "Your manual settings will be overridden by the" + " dedicated options.\n" + "This message will be displayed until you remove them" + " from the JVM arguments."), + QMessageBox::Warning)->exec(); + return false; + } + return true; +} + +void JavaCommon::TestCheck::javaWasOk(JavaCheckResult result) +{ + QString text; + text += tr("Java test succeeded!<br />Platform reported: %1<br />Java version " + "reported: %2<br />").arg(result.realPlatform, result.javaVersion); + if (result.stderr.size()) + { + auto htmlError = result.stderr; + htmlError.replace('\n', "<br />"); + text += tr("<br />Warnings:<br /><font color=\"orange\">%1</font>").arg(htmlError); + } + CustomMessageBox::selectable(m_parent, tr("Java test success"), text, + QMessageBox::Information)->show(); +} + +void JavaCommon::TestCheck::javaArgsWereBad(JavaCheckResult result) +{ + auto htmlError = result.stderr; + QString text; + htmlError.replace('\n', "<br />"); + text += tr("The specified java binary didn't work with the arguments you provided:<br />"); + text += tr("<font color=\"red\">%1</font>").arg(htmlError); + CustomMessageBox::selectable(m_parent, tr("Java test failure"), text, QMessageBox::Warning) + ->show(); +} + +void JavaCommon::TestCheck::javaBinaryWasBad(JavaCheckResult result) +{ + QString text; + text += tr( + "The specified java binary didn't work.<br />You should use the auto-detect feature, " + "or set the path to the java executable.<br />"); + CustomMessageBox::selectable(m_parent, tr("Java test failure"), text, QMessageBox::Warning) + ->show(); +} + +void JavaCommon::TestCheck::run() +{ + if (!JavaCommon::checkJVMArgs(m_args, m_parent)) + { + emit finished(); + return; + } + checker.reset(new JavaChecker()); + connect(checker.get(), SIGNAL(checkFinished(JavaCheckResult)), this, + SLOT(checkFinished(JavaCheckResult))); + checker->m_path = m_path; + checker->performCheck(); +} + +void JavaCommon::TestCheck::checkFinished(JavaCheckResult result) +{ + if (!result.valid) + { + javaBinaryWasBad(result); + emit finished(); + return; + } + checker.reset(new JavaChecker()); + connect(checker.get(), SIGNAL(checkFinished(JavaCheckResult)), this, + SLOT(checkFinishedWithArgs(JavaCheckResult))); + checker->m_path = m_path; + checker->m_args = m_args; + checker->m_minMem = m_minMem; + checker->m_maxMem = m_maxMem; + if (Strings::naturalCompare(result.javaVersion, "1.8", Qt::CaseInsensitive) < 0) + { + checker->m_permGen = m_permGen; + } + checker->performCheck(); +} + +void JavaCommon::TestCheck::checkFinishedWithArgs(JavaCheckResult result) +{ + if (result.valid) + { + javaWasOk(result); + emit finished(); + return; + } + javaArgsWereBad(result); + emit finished(); +} |