diff options
| author | Trial97 <alexandru.tripon97@gmail.com> | 2023-07-09 22:47:38 +0300 | 
|---|---|---|
| committer | Trial97 <alexandru.tripon97@gmail.com> | 2023-07-09 22:47:38 +0300 | 
| commit | 159f14c0768a1cd8ab99b8a46f2021d163e6740c (patch) | |
| tree | 71c0297ea88bb910407463ee92ca22b065cf8ce7 /launcher/ui | |
| parent | 67d473aab773e7f94c394ebdde05581dc8f805de (diff) | |
| download | PrismLauncher-159f14c0768a1cd8ab99b8a46f2021d163e6740c.tar.gz PrismLauncher-159f14c0768a1cd8ab99b8a46f2021d163e6740c.tar.bz2 PrismLauncher-159f14c0768a1cd8ab99b8a46f2021d163e6740c.zip | |
feat:unlocked versions page
Signed-off-by: Trial97 <alexandru.tripon97@gmail.com>
Diffstat (limited to 'launcher/ui')
| -rw-r--r-- | launcher/ui/pages/instance/VersionPage.cpp | 313 | ||||
| -rw-r--r-- | launcher/ui/pages/instance/VersionPage.h | 55 | 
2 files changed, 138 insertions, 230 deletions
| diff --git a/launcher/ui/pages/instance/VersionPage.cpp b/launcher/ui/pages/instance/VersionPage.cpp index 59107c53..7db1b19f 100644 --- a/launcher/ui/pages/instance/VersionPage.cpp +++ b/launcher/ui/pages/instance/VersionPage.cpp @@ -40,14 +40,13 @@  #include "Application.h" -#include <QMessageBox> -#include <QLabel> +#include <QAbstractItemModel>  #include <QEvent>  #include <QKeyEvent> +#include <QLabel> +#include <QListView>  #include <QMenu> -#include <QAbstractItemModel>  #include <QMessageBox> -#include <QListView>  #include <QString>  #include <QUrl> @@ -55,49 +54,42 @@  #include "ui_VersionPage.h"  #include "ui/dialogs/CustomMessageBox.h" -#include "ui/dialogs/VersionSelectDialog.h"  #include "ui/dialogs/NewComponentDialog.h"  #include "ui/dialogs/ProgressDialog.h" +#include "ui/dialogs/VersionSelectDialog.h"  #include "ui/GuiUtil.h" +#include "DesktopServices.h" +#include "Exception.h" +#include "Version.h" +#include "icons/IconList.h"  #include "minecraft/PackProfile.h"  #include "minecraft/auth/AccountList.h"  #include "minecraft/mod/Mod.h" -#include "icons/IconList.h" -#include "Exception.h" -#include "Version.h" -#include "DesktopServices.h"  #include "meta/Index.h"  #include "meta/VersionList.h" -class IconProxy : public QIdentityProxyModel -{ +class IconProxy : public QIdentityProxyModel {      Q_OBJECT -public: - -    IconProxy(QWidget *parentWidget) : QIdentityProxyModel(parentWidget) +   public: +    IconProxy(QWidget* parentWidget) : QIdentityProxyModel(parentWidget)      {          connect(parentWidget, &QObject::destroyed, this, &IconProxy::widgetGone);          m_parentWidget = parentWidget;      } -    virtual QVariant data(const QModelIndex &proxyIndex, int role = Qt::DisplayRole) const override +    virtual QVariant data(const QModelIndex& proxyIndex, int role = Qt::DisplayRole) const override      {          QVariant var = QIdentityProxyModel::data(proxyIndex, role);          int column = proxyIndex.column(); -        if(column == 0 && role == Qt::DecorationRole && m_parentWidget) -        { -            if(!var.isNull()) -            { +        if (column == 0 && role == Qt::DecorationRole && m_parentWidget) { +            if (!var.isNull()) {                  auto string = var.toString(); -                if(string == "warning") -                { +                if (string == "warning") {                      return APPLICATION->getThemedIcon("status-yellow"); -                } -                else if(string == "error") -                { +                } else if (string == "error") {                      return APPLICATION->getThemedIcon("status-bad");                  }              } @@ -105,14 +97,11 @@ public:          }          return var;      } -private slots: -    void widgetGone() -    { -        m_parentWidget = nullptr; -    } +   private slots: +    void widgetGone() { m_parentWidget = nullptr; } -private: -    QWidget *m_parentWidget = nullptr; +   private: +    QWidget* m_parentWidget = nullptr;  };  QIcon VersionPage::icon() const @@ -144,15 +133,14 @@ void VersionPage::closedImpl()      m_wide_bar_setting->set(ui->toolBar->getVisibilityState());  } -QMenu * VersionPage::createPopupMenu() +QMenu* VersionPage::createPopupMenu()  {      QMenu* filteredMenu = QMainWindow::createPopupMenu(); -    filteredMenu->removeAction( ui->toolBar->toggleViewAction() ); +    filteredMenu->removeAction(ui->toolBar->toggleViewAction());      return filteredMenu;  } -VersionPage::VersionPage(MinecraftInstance *inst, QWidget *parent) -    : QMainWindow(parent), ui(new Ui::VersionPage), m_inst(inst) +VersionPage::VersionPage(MinecraftInstance* inst, QWidget* parent) : QMainWindow(parent), ui(new Ui::VersionPage), m_inst(inst)  {      ui->setupUi(this); @@ -182,10 +170,8 @@ VersionPage::VersionPage(MinecraftInstance *inst, QWidget *parent)      connect(smodel, &QItemSelectionModel::currentChanged, this, &VersionPage::packageCurrent);      connect(m_profile.get(), &PackProfile::minecraftChanged, this, &VersionPage::updateVersionControls); -    controlsEnabled = !m_inst->isRunning();      updateVersionControls();      preselect(0); -    connect(m_inst, &BaseInstance::runningStatusChanged, this, &VersionPage::updateRunningStatus);      connect(ui->packageView, &ModListView::customContextMenuRequested, this, &VersionPage::showContextMenu);      connect(ui->filterEdit, &QLineEdit::textChanged, this, &VersionPage::onFilterTextChanged);  } @@ -202,18 +188,16 @@ void VersionPage::showContextMenu(const QPoint& pos)      delete menu;  } -void VersionPage::packageCurrent(const QModelIndex ¤t, const QModelIndex &previous) +void VersionPage::packageCurrent(const QModelIndex& current, const QModelIndex& previous)  { -    if (!current.isValid()) -    { +    if (!current.isValid()) {          ui->frame->clear();          return;      }      int row = current.row();      auto patch = m_profile->getComponent(row);      auto severity = patch->getProblemSeverity(); -    switch(severity) -    { +    switch (severity) {          case ProblemSeverity::Warning:              ui->frame->setName(tr("%1 possibly has issues.").arg(patch->getName()));              break; @@ -226,16 +210,12 @@ void VersionPage::packageCurrent(const QModelIndex ¤t, const QModelIndex &              return;      } -    auto &problems = patch->getProblems(); +    auto& problems = patch->getProblems();      QString problemOut; -    for (auto &problem: problems) -    { -        if(problem.m_severity == ProblemSeverity::Error) -        { +    for (auto& problem : problems) { +        if (problem.m_severity == ProblemSeverity::Error) {              problemOut += tr("Error: "); -        } -        else if(problem.m_severity == ProblemSeverity::Warning) -        { +        } else if (problem.m_severity == ProblemSeverity::Warning) {              problemOut += tr("Warning: ");          }          problemOut += problem.m_description; @@ -244,71 +224,56 @@ void VersionPage::packageCurrent(const QModelIndex ¤t, const QModelIndex &      ui->frame->setDescription(problemOut);  } -void VersionPage::updateRunningStatus(bool running) -{ -    if(controlsEnabled == running) { -        controlsEnabled = !running; -        updateVersionControls(); -    } -} -  void VersionPage::updateVersionControls()  {      // FIXME: this is a dirty hack      auto minecraftVersion = Version(m_profile->getComponentVersion("net.minecraft")); -    ui->actionInstall_Forge->setEnabled(controlsEnabled); +    ui->actionInstall_Forge->setEnabled(true);      bool supportsFabric = minecraftVersion >= Version("1.14"); -    ui->actionInstall_Fabric->setEnabled(controlsEnabled && supportsFabric); +    ui->actionInstall_Fabric->setEnabled(supportsFabric);      bool supportsQuilt = minecraftVersion >= Version("1.14"); -    ui->actionInstall_Quilt->setEnabled(controlsEnabled && supportsQuilt); +    ui->actionInstall_Quilt->setEnabled(supportsQuilt);      bool supportsLiteLoader = minecraftVersion <= Version("1.12.2"); -    ui->actionInstall_LiteLoader->setEnabled(controlsEnabled && supportsLiteLoader); +    ui->actionInstall_LiteLoader->setEnabled(supportsLiteLoader);      updateButtons();  }  void VersionPage::updateButtons(int row)  { -    if(row == -1) +    if (row == -1)          row = currentRow();      auto patch = m_profile->getComponent(row); -    ui->actionRemove->setEnabled(controlsEnabled && patch && patch->isRemovable()); -    ui->actionMove_down->setEnabled(controlsEnabled && patch && patch->isMoveable()); -    ui->actionMove_up->setEnabled(controlsEnabled && patch && patch->isMoveable()); -    ui->actionChange_version->setEnabled(controlsEnabled && patch && patch->isVersionChangeable()); -    ui->actionEdit->setEnabled(controlsEnabled && patch && patch->isCustom()); -    ui->actionCustomize->setEnabled(controlsEnabled && patch && patch->isCustomizable()); -    ui->actionRevert->setEnabled(controlsEnabled && patch && patch->isRevertible()); -    ui->actionDownload_All->setEnabled(controlsEnabled); -    ui->actionAdd_Empty->setEnabled(controlsEnabled); -    ui->actionImport_Components->setEnabled(controlsEnabled); -    ui->actionReload->setEnabled(controlsEnabled); -    ui->actionReplace_Minecraft_jar->setEnabled(controlsEnabled); -    ui->actionAdd_to_Minecraft_jar->setEnabled(controlsEnabled); -    ui->actionAdd_Agents->setEnabled(controlsEnabled); +    ui->actionRemove->setEnabled(patch && patch->isRemovable()); +    ui->actionMove_down->setEnabled(patch && patch->isMoveable()); +    ui->actionMove_up->setEnabled(patch && patch->isMoveable()); +    ui->actionChange_version->setEnabled(patch && patch->isVersionChangeable()); +    ui->actionEdit->setEnabled(patch && patch->isCustom()); +    ui->actionCustomize->setEnabled(patch && patch->isCustomizable()); +    ui->actionRevert->setEnabled(patch && patch->isRevertible()); +    ui->actionDownload_All->setEnabled(true); +    ui->actionAdd_Empty->setEnabled(true); +    ui->actionImport_Components->setEnabled(true); +    ui->actionReload->setEnabled(true); +    ui->actionReplace_Minecraft_jar->setEnabled(true); +    ui->actionAdd_to_Minecraft_jar->setEnabled(true); +    ui->actionAdd_Agents->setEnabled(true);  }  bool VersionPage::reloadPackProfile()  { -    try -    { +    try {          m_profile->reload(Net::Mode::Online);          return true; -    } -    catch (const Exception &e) -    { +    } catch (const Exception& e) {          QMessageBox::critical(this, tr("Error"), e.cause());          return false; -    } -    catch (...) -    { -        QMessageBox::critical( -            this, tr("Error"), -            tr("Couldn't load the instance profile.")); +    } catch (...) { +        QMessageBox::critical(this, tr("Error"), tr("Couldn't load the instance profile."));          return false;      }  } @@ -321,14 +286,12 @@ void VersionPage::on_actionReload_triggered()  void VersionPage::on_actionRemove_triggered()  { -    if (!ui->packageView->currentIndex().isValid()) -    { +    if (!ui->packageView->currentIndex().isValid()) {          return;      }      int index = ui->packageView->currentIndex().row();      auto component = m_profile->getComponent(index); -    if (component->isCustom()) -    { +    if (component->isCustom()) {          auto response = CustomMessageBox::selectable(this, tr("Confirm Removal"),                                                       tr("You are about to remove \"%1\".\n"                                                          "This is permanent and will completely remove the custom component.\n\n" @@ -341,8 +304,7 @@ void VersionPage::on_actionRemove_triggered()              return;      }      // FIXME: use actual model, not reloading. -    if (!m_profile->remove(index)) -    { +    if (!m_profile->remove(index)) {          QMessageBox::critical(this, tr("Error"), tr("Couldn't remove file"));      }      updateButtons(); @@ -352,17 +314,16 @@ void VersionPage::on_actionRemove_triggered()  void VersionPage::on_actionInstall_mods_triggered()  { -    if(m_container) -    { +    if (m_container) {          m_container->selectPage("mods");      }  }  void VersionPage::on_actionAdd_to_Minecraft_jar_triggered()  { -    auto list = GuiUtil::BrowseForFiles("jarmod", tr("Select jar mods"), tr("Minecraft.jar mods (*.zip *.jar)"), APPLICATION->settings()->get("CentralModsDir").toString(), this->parentWidget()); -    if(!list.empty()) -    { +    auto list = GuiUtil::BrowseForFiles("jarmod", tr("Select jar mods"), tr("Minecraft.jar mods (*.zip *.jar)"), +                                        APPLICATION->settings()->get("CentralModsDir").toString(), this->parentWidget()); +    if (!list.empty()) {          m_profile->installJarMods(list);      }      updateButtons(); @@ -370,9 +331,9 @@ void VersionPage::on_actionAdd_to_Minecraft_jar_triggered()  void VersionPage::on_actionReplace_Minecraft_jar_triggered()  { -    auto jarPath = GuiUtil::BrowseForFile("jar", tr("Select jar"), tr("Minecraft.jar replacement (*.jar)"), APPLICATION->settings()->get("CentralModsDir").toString(), this->parentWidget()); -    if(!jarPath.isEmpty()) -    { +    auto jarPath = GuiUtil::BrowseForFile("jar", tr("Select jar"), tr("Minecraft.jar replacement (*.jar)"), +                                          APPLICATION->settings()->get("CentralModsDir").toString(), this->parentWidget()); +    if (!jarPath.isEmpty()) {          m_profile->installCustomJar(jarPath);      }      updateButtons(); @@ -406,12 +367,9 @@ void VersionPage::on_actionAdd_Agents_triggered()  void VersionPage::on_actionMove_up_triggered()  { -    try -    { +    try {          m_profile->move(currentRow(), PackProfile::MoveUp); -    } -    catch (const Exception &e) -    { +    } catch (const Exception& e) {          QMessageBox::critical(this, tr("Error"), e.cause());      }      updateButtons(); @@ -419,12 +377,9 @@ void VersionPage::on_actionMove_up_triggered()  void VersionPage::on_actionMove_down_triggered()  { -    try -    { +    try {          m_profile->move(currentRow(), PackProfile::MoveDown); -    } -    catch (const Exception &e) -    { +    } catch (const Exception& e) {          QMessageBox::critical(this, tr("Error"), e.cause());      }      updateButtons(); @@ -433,39 +388,32 @@ void VersionPage::on_actionMove_down_triggered()  void VersionPage::on_actionChange_version_triggered()  {      auto versionRow = currentRow(); -    if(versionRow == -1) -    { +    if (versionRow == -1) {          return;      }      auto patch = m_profile->getComponent(versionRow);      auto name = patch->getName();      auto list = patch->getVersionList(); -    if(!list) -    { +    if (!list) {          return;      }      auto uid = list->uid();      // FIXME: this is a horrible HACK. Get version filtering information from the actual metadata... -    if(uid == "net.minecraftforge") -    { +    if (uid == "net.minecraftforge") {          on_actionInstall_Forge_triggered();          return; -    } -    else if (uid == "com.mumfrey.liteloader") -    { +    } else if (uid == "com.mumfrey.liteloader") {          on_actionInstall_LiteLoader_triggered();          return;      }      VersionSelectDialog vselect(list.get(), tr("Change %1 version").arg(name), this); -    if (uid == "net.fabricmc.intermediary" || uid == "org.quiltmc.hashed") -    { +    if (uid == "net.fabricmc.intermediary" || uid == "org.quiltmc.hashed") {          vselect.setEmptyString(tr("No intermediary mappings versions are currently available."));          vselect.setEmptyErrorString(tr("Couldn't load or download the intermediary mappings version lists!"));          vselect.setExactFilter(BaseVersionList::ParentVersionRole, m_profile->getComponentVersion("net.minecraft"));      }      auto currentVersion = patch->getVersion(); -    if(!currentVersion.isEmpty()) -    { +    if (!currentVersion.isEmpty()) {          vselect.setCurrentVersion(currentVersion);      }      if (!vselect.exec() || !vselect.selectedVersion()) @@ -473,8 +421,7 @@ void VersionPage::on_actionChange_version_triggered()      qDebug() << "Change" << uid << "to" << vselect.selectedVersion()->descriptor();      bool important = false; -    if(uid == "net.minecraft") -    { +    if (uid == "net.minecraft") {          important = true;      }      m_profile->setComponentVersion(uid, vselect.selectedVersion()->descriptor(), important); @@ -484,19 +431,17 @@ void VersionPage::on_actionChange_version_triggered()  void VersionPage::on_actionDownload_All_triggered()  { -    if (!APPLICATION->accounts()->anyAccountIsValid()) -    { -        CustomMessageBox::selectable( -            this, tr("Error"), -            tr("Cannot download Minecraft or update instances unless you have at least " -               "one account added.\nPlease add your Mojang or Minecraft account."), -            QMessageBox::Warning)->show(); +    if (!APPLICATION->accounts()->anyAccountIsValid()) { +        CustomMessageBox::selectable(this, tr("Error"), +                                     tr("Cannot download Minecraft or update instances unless you have at least " +                                        "one account added.\nPlease add your Mojang or Minecraft account."), +                                     QMessageBox::Warning) +            ->show();          return;      }      auto updateTask = m_inst->createUpdateTask(Net::Mode::Online); -    if (!updateTask) -    { +    if (!updateTask) {          return;      }      ProgressDialog tDialog(this); @@ -510,28 +455,26 @@ void VersionPage::on_actionDownload_All_triggered()  void VersionPage::on_actionInstall_Forge_triggered()  {      auto vlist = APPLICATION->metadataIndex()->get("net.minecraftforge"); -    if(!vlist) -    { +    if (!vlist) {          return;      }      VersionSelectDialog vselect(vlist.get(), tr("Select Forge version"), this);      vselect.setExactFilter(BaseVersionList::ParentVersionRole, m_profile->getComponentVersion("net.minecraft")); -    vselect.setEmptyString(tr("No Forge versions are currently available for Minecraft ") + m_profile->getComponentVersion("net.minecraft")); +    vselect.setEmptyString(tr("No Forge versions are currently available for Minecraft ") + +                           m_profile->getComponentVersion("net.minecraft"));      vselect.setEmptyErrorString(tr("Couldn't load or download the Forge version lists!"));      auto currentVersion = m_profile->getComponentVersion("net.minecraftforge"); -    if(!currentVersion.isEmpty()) -    { +    if (!currentVersion.isEmpty()) {          vselect.setCurrentVersion(currentVersion);      } -    if (vselect.exec() && vselect.selectedVersion()) -    { +    if (vselect.exec() && vselect.selectedVersion()) {          auto vsn = vselect.selectedVersion();          m_profile->setComponentVersion("net.minecraftforge", vsn->descriptor());          m_profile->resolve(Net::Mode::Online);          // m_profile->installVersion(); -        preselect(m_profile->rowCount(QModelIndex())-1); +        preselect(m_profile->rowCount(QModelIndex()) - 1);          m_container->refreshContainer();      }  } @@ -539,8 +482,7 @@ void VersionPage::on_actionInstall_Forge_triggered()  void VersionPage::on_actionInstall_Fabric_triggered()  {      auto vlist = APPLICATION->metadataIndex()->get("net.fabricmc.fabric-loader"); -    if(!vlist) -    { +    if (!vlist) {          return;      }      VersionSelectDialog vselect(vlist.get(), tr("Select Fabric Loader version"), this); @@ -548,17 +490,15 @@ void VersionPage::on_actionInstall_Fabric_triggered()      vselect.setEmptyErrorString(tr("Couldn't load or download the Fabric Loader version lists!"));      auto currentVersion = m_profile->getComponentVersion("net.fabricmc.fabric-loader"); -    if(!currentVersion.isEmpty()) -    { +    if (!currentVersion.isEmpty()) {          vselect.setCurrentVersion(currentVersion);      } -    if (vselect.exec() && vselect.selectedVersion()) -    { +    if (vselect.exec() && vselect.selectedVersion()) {          auto vsn = vselect.selectedVersion();          m_profile->setComponentVersion("net.fabricmc.fabric-loader", vsn->descriptor());          m_profile->resolve(Net::Mode::Online); -        preselect(m_profile->rowCount(QModelIndex())-1); +        preselect(m_profile->rowCount(QModelIndex()) - 1);          m_container->refreshContainer();      }  } @@ -566,8 +506,7 @@ void VersionPage::on_actionInstall_Fabric_triggered()  void VersionPage::on_actionInstall_Quilt_triggered()  {      auto vlist = APPLICATION->metadataIndex()->get("org.quiltmc.quilt-loader"); -    if(!vlist) -    { +    if (!vlist) {          return;      }      VersionSelectDialog vselect(vlist.get(), tr("Select Quilt Loader version"), this); @@ -575,17 +514,15 @@ void VersionPage::on_actionInstall_Quilt_triggered()      vselect.setEmptyErrorString(tr("Couldn't load or download the Quilt Loader version lists!"));      auto currentVersion = m_profile->getComponentVersion("org.quiltmc.quilt-loader"); -    if(!currentVersion.isEmpty()) -    { +    if (!currentVersion.isEmpty()) {          vselect.setCurrentVersion(currentVersion);      } -    if (vselect.exec() && vselect.selectedVersion()) -    { +    if (vselect.exec() && vselect.selectedVersion()) {          auto vsn = vselect.selectedVersion();          m_profile->setComponentVersion("org.quiltmc.quilt-loader", vsn->descriptor());          m_profile->resolve(Net::Mode::Online); -        preselect(m_profile->rowCount(QModelIndex())-1); +        preselect(m_profile->rowCount(QModelIndex()) - 1);          m_container->refreshContainer();      }  } @@ -594,14 +531,12 @@ void VersionPage::on_actionAdd_Empty_triggered()  {      NewComponentDialog compdialog(QString(), QString(), this);      QStringList blacklist; -    for(int i = 0; i < m_profile->rowCount(); i++) -    { +    for (int i = 0; i < m_profile->rowCount(); i++) {          auto comp = m_profile->getComponent(i);          blacklist.push_back(comp->getID());      }      compdialog.setBlacklist(blacklist); -    if (compdialog.exec()) -    { +    if (compdialog.exec()) {          qDebug() << "name:" << compdialog.name();          qDebug() << "uid:" << compdialog.uid();          m_profile->installEmpty(compdialog.uid(), compdialog.name()); @@ -611,28 +546,26 @@ void VersionPage::on_actionAdd_Empty_triggered()  void VersionPage::on_actionInstall_LiteLoader_triggered()  {      auto vlist = APPLICATION->metadataIndex()->get("com.mumfrey.liteloader"); -    if(!vlist) -    { +    if (!vlist) {          return;      }      VersionSelectDialog vselect(vlist.get(), tr("Select LiteLoader version"), this);      vselect.setExactFilter(BaseVersionList::ParentVersionRole, m_profile->getComponentVersion("net.minecraft")); -    vselect.setEmptyString(tr("No LiteLoader versions are currently available for Minecraft ") + m_profile->getComponentVersion("net.minecraft")); +    vselect.setEmptyString(tr("No LiteLoader versions are currently available for Minecraft ") + +                           m_profile->getComponentVersion("net.minecraft"));      vselect.setEmptyErrorString(tr("Couldn't load or download the LiteLoader version lists!"));      auto currentVersion = m_profile->getComponentVersion("com.mumfrey.liteloader"); -    if(!currentVersion.isEmpty()) -    { +    if (!currentVersion.isEmpty()) {          vselect.setCurrentVersion(currentVersion);      } -    if (vselect.exec() && vselect.selectedVersion()) -    { +    if (vselect.exec() && vselect.selectedVersion()) {          auto vsn = vselect.selectedVersion();          m_profile->setComponentVersion("com.mumfrey.liteloader", vsn->descriptor());          m_profile->resolve(Net::Mode::Online);          // m_profile->installVersion(vselect.selectedVersion()); -        preselect(m_profile->rowCount(QModelIndex())-1); +        preselect(m_profile->rowCount(QModelIndex()) - 1);          m_container->refreshContainer();      }  } @@ -647,7 +580,7 @@ void VersionPage::on_actionMinecraftFolder_triggered()      DesktopServices::openDirectory(m_inst->gameRoot(), true);  } -void VersionPage::versionCurrent(const QModelIndex ¤t, const QModelIndex &previous) +void VersionPage::versionCurrent(const QModelIndex& current, const QModelIndex& previous)  {      currentIdx = current.row();      updateButtons(currentIdx); @@ -655,16 +588,13 @@ void VersionPage::versionCurrent(const QModelIndex ¤t, const QModelIndex &  void VersionPage::preselect(int row)  { -    if(row < 0) -    { +    if (row < 0) {          row = 0;      } -    if(row >= m_profile->rowCount(QModelIndex())) -    { +    if (row >= m_profile->rowCount(QModelIndex())) {          row = m_profile->rowCount(QModelIndex()) - 1;      } -    if(row < 0) -    { +    if (row < 0) {          return;      }      auto model_index = m_profile->index(row); @@ -680,8 +610,7 @@ void VersionPage::onGameUpdateError(QString error)  ComponentPtr VersionPage::current()  {      auto row = currentRow(); -    if(row < 0) -    { +    if (row < 0) {          return nullptr;      }      return m_profile->getComponent(row); @@ -689,8 +618,7 @@ ComponentPtr VersionPage::current()  int VersionPage::currentRow()  { -    if (ui->packageView->selectionModel()->selectedRows().isEmpty()) -    { +    if (ui->packageView->selectionModel()->selectedRows().isEmpty()) {          return -1;      }      return ui->packageView->selectionModel()->selectedRows().first().row(); @@ -699,18 +627,15 @@ int VersionPage::currentRow()  void VersionPage::on_actionCustomize_triggered()  {      auto version = currentRow(); -    if(version == -1) -    { +    if (version == -1) {          return;      }      auto patch = m_profile->getComponent(version); -    if(!patch->getVersionFile()) -    { +    if (!patch->getVersionFile()) {          // TODO: wait for the update task to finish here...          return;      } -    if(!m_profile->customize(version)) -    { +    if (!m_profile->customize(version)) {          // TODO: some error box here      }      updateButtons(); @@ -720,13 +645,11 @@ void VersionPage::on_actionCustomize_triggered()  void VersionPage::on_actionEdit_triggered()  {      auto version = current(); -    if(!version) -    { +    if (!version) {          return;      }      auto filename = version->getFilename(); -    if(!QFileInfo::exists(filename)) -    { +    if (!QFileInfo::exists(filename)) {          qWarning() << "file" << filename << "can't be opened for editing, doesn't exist!";          return;      } @@ -736,8 +659,7 @@ void VersionPage::on_actionEdit_triggered()  void VersionPage::on_actionRevert_triggered()  {      auto version = currentRow(); -    if(version == -1) -    { +    if (version == -1) {          return;      }      auto component = m_profile->getComponent(version); @@ -753,8 +675,7 @@ void VersionPage::on_actionRevert_triggered()      if (response != QMessageBox::Yes)          return; -    if(!m_profile->revertToBase(version)) -    { +    if (!m_profile->revertToBase(version)) {          // TODO: some error box here      }      updateButtons(); @@ -762,7 +683,7 @@ void VersionPage::on_actionRevert_triggered()      m_container->refreshContainer();  } -void VersionPage::onFilterTextChanged(const QString &newContents) +void VersionPage::onFilterTextChanged(const QString& newContents)  {      m_filterModel->setFilterFixedString(newContents);  } diff --git a/launcher/ui/pages/instance/VersionPage.h b/launcher/ui/pages/instance/VersionPage.h index d0087714..45d383f4 100644 --- a/launcher/ui/pages/instance/VersionPage.h +++ b/launcher/ui/pages/instance/VersionPage.h @@ -46,38 +46,27 @@  #include "minecraft/PackProfile.h"  #include "ui/pages/BasePage.h" -namespace Ui -{ +namespace Ui {  class VersionPage;  } -class VersionPage : public QMainWindow, public BasePage -{ +class VersionPage : public QMainWindow, public BasePage {      Q_OBJECT -public: -    explicit VersionPage(MinecraftInstance *inst, QWidget *parent = 0); +   public: +    explicit VersionPage(MinecraftInstance* inst, QWidget* parent = 0);      virtual ~VersionPage(); -    virtual QString displayName() const override -    { -        return tr("Version"); -    } +    virtual QString displayName() const override { return tr("Version"); }      virtual QIcon icon() const override; -    virtual QString id() const override -    { -        return "version"; -    } -    virtual QString helpPage() const override -    { -        return "Instance-Version"; -    } +    virtual QString id() const override { return "version"; } +    virtual QString helpPage() const override { return "Instance-Version"; }      virtual bool shouldDisplay() const override;      void retranslate() override;      void openedImpl() override;      void closedImpl() override; -private slots: +   private slots:      void on_actionChange_version_triggered();      void on_actionInstall_Forge_triggered();      void on_actionInstall_Fabric_triggered(); @@ -103,36 +92,34 @@ private slots:      void updateVersionControls(); -private: +   private:      ComponentPtr current();      int currentRow();      void updateButtons(int row = -1);      void preselect(int row = 0);      int doUpdate(); -protected: -    QMenu * createPopupMenu() override; +   protected: +    QMenu* createPopupMenu() override;      /// FIXME: this shouldn't be necessary!      bool reloadPackProfile(); -private: -    Ui::VersionPage *ui; -    QSortFilterProxyModel *m_filterModel; +   private: +    Ui::VersionPage* ui; +    QSortFilterProxyModel* m_filterModel;      std::shared_ptr<PackProfile> m_profile; -    MinecraftInstance *m_inst; +    MinecraftInstance* m_inst;      int currentIdx = 0; -    bool controlsEnabled = false;      std::shared_ptr<Setting> m_wide_bar_setting = nullptr; -public slots: -    void versionCurrent(const QModelIndex ¤t, const QModelIndex &previous); +   public slots: +    void versionCurrent(const QModelIndex& current, const QModelIndex& previous); -private slots: -    void updateRunningStatus(bool running); +   private slots:      void onGameUpdateError(QString error); -    void packageCurrent(const QModelIndex ¤t, const QModelIndex &previous); -    void showContextMenu(const QPoint &pos); -    void onFilterTextChanged(const QString & newContents); +    void packageCurrent(const QModelIndex& current, const QModelIndex& previous); +    void showContextMenu(const QPoint& pos); +    void onFilterTextChanged(const QString& newContents);  }; | 
