modsettings.cpp 4.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162
  1. /*
  2. * modsettings.cpp, part of VCMI engine
  3. *
  4. * Authors: listed in file AUTHORS in main folder
  5. *
  6. * License: GNU General Public License v2.0 or later
  7. * Full text of license available in license.txt file, in main folder
  8. *
  9. */
  10. #include "StdInc.h"
  11. #include "modsettings.h"
  12. #include "ui_modsettings.h"
  13. #include "../mapcontroller.h"
  14. #include "../../lib/modding/ModDescription.h"
  15. #include "../../lib/modding/CModHandler.h"
  16. #include "../../lib/mapping/CMapService.h"
  17. void traverseNode(QTreeWidgetItem * item, std::function<void(QTreeWidgetItem*)> action)
  18. {
  19. // Do something with item
  20. action(item);
  21. for (int i = 0; i < item->childCount(); ++i)
  22. traverseNode(item->child(i), action);
  23. }
  24. ModSettings::ModSettings(QWidget *parent) :
  25. AbstractSettings(parent),
  26. ui(new Ui::ModSettings)
  27. {
  28. ui->setupUi(this);
  29. }
  30. ModSettings::~ModSettings()
  31. {
  32. delete ui;
  33. }
  34. void ModSettings::initialize(MapController & c)
  35. {
  36. AbstractSettings::initialize(c);
  37. //mods management
  38. //collect all active mods
  39. QMap<QString, QTreeWidgetItem*> addedMods;
  40. QSet<QString> modsToProcess;
  41. ui->treeMods->blockSignals(true);
  42. auto createModTreeWidgetItem = [&](QTreeWidgetItem * parent, const ModDescription & modInfo)
  43. {
  44. auto item = new QTreeWidgetItem(parent, {QString::fromStdString(modInfo.getName()), QString::fromStdString(modInfo.getVersion().toString())});
  45. item->setData(0, Qt::UserRole, QVariant(QString::fromStdString(modInfo.getID())));
  46. item->setFlags(item->flags() | Qt::ItemIsUserCheckable);
  47. item->setCheckState(0, controller->map()->mods.count(modInfo.getID()) ? Qt::Checked : Qt::Unchecked);
  48. //set parent check
  49. if(parent && item->checkState(0) == Qt::Checked)
  50. parent->setCheckState(0, Qt::Checked);
  51. return item;
  52. };
  53. for(const auto & modName : VLC->modh->getActiveMods())
  54. {
  55. QString qmodName = QString::fromStdString(modName);
  56. if(qmodName.split(".").size() == 1)
  57. {
  58. const auto & modInfo = VLC->modh->getModInfo(modName);
  59. addedMods[qmodName] = createModTreeWidgetItem(nullptr, modInfo);
  60. ui->treeMods->addTopLevelItem(addedMods[qmodName]);
  61. }
  62. else
  63. {
  64. modsToProcess.insert(qmodName);
  65. }
  66. }
  67. for(auto qmodIter = modsToProcess.begin(); qmodIter != modsToProcess.end();)
  68. {
  69. auto qmodName = *qmodIter;
  70. auto pieces = qmodName.split(".");
  71. assert(pieces.size() > 1);
  72. pieces.pop_back();
  73. auto qs = pieces.join(".");
  74. if(addedMods.count(qs))
  75. {
  76. const auto & modInfo = VLC->modh->getModInfo(qmodName.toStdString());
  77. addedMods[qmodName] = createModTreeWidgetItem(addedMods[qs], modInfo);
  78. modsToProcess.erase(qmodIter);
  79. qmodIter = modsToProcess.begin();
  80. }
  81. else
  82. ++qmodIter;
  83. }
  84. ui->treeMods->blockSignals(false);
  85. }
  86. void ModSettings::update()
  87. {
  88. //Mod management
  89. auto widgetAction = [&](QTreeWidgetItem * item)
  90. {
  91. if(item->checkState(0) == Qt::Checked)
  92. {
  93. auto modName = item->data(0, Qt::UserRole).toString().toStdString();
  94. controller->map()->mods[modName] = VLC->modh->getModInfo(modName).getVerificationInfo();
  95. }
  96. };
  97. controller->map()->mods.clear();
  98. for (int i = 0; i < ui->treeMods->topLevelItemCount(); ++i)
  99. {
  100. QTreeWidgetItem *item = ui->treeMods->topLevelItem(i);
  101. traverseNode(item, widgetAction);
  102. }
  103. }
  104. void ModSettings::updateModWidgetBasedOnMods(const ModCompatibilityInfo & mods)
  105. {
  106. //Mod management
  107. auto widgetAction = [&](QTreeWidgetItem * item)
  108. {
  109. auto modName = item->data(0, Qt::UserRole).toString().toStdString();
  110. item->setCheckState(0, mods.count(modName) ? Qt::Checked : Qt::Unchecked);
  111. };
  112. for (int i = 0; i < ui->treeMods->topLevelItemCount(); ++i)
  113. {
  114. QTreeWidgetItem *item = ui->treeMods->topLevelItem(i);
  115. traverseNode(item, widgetAction);
  116. }
  117. }
  118. void ModSettings::on_modResolution_map_clicked()
  119. {
  120. updateModWidgetBasedOnMods(MapController::modAssessmentMap(*controller->map()));
  121. }
  122. void ModSettings::on_modResolution_full_clicked()
  123. {
  124. updateModWidgetBasedOnMods(MapController::modAssessmentAll());
  125. }
  126. void ModSettings::on_treeMods_itemChanged(QTreeWidgetItem *item, int column)
  127. {
  128. //set state for children
  129. for (int i = 0; i < item->childCount(); ++i)
  130. item->child(i)->setCheckState(0, item->checkState(0));
  131. //set state for parent
  132. ui->treeMods->blockSignals(true);
  133. if(item->checkState(0) == Qt::Checked)
  134. {
  135. while(item->parent())
  136. {
  137. item->parent()->setCheckState(0, Qt::Checked);
  138. item = item->parent();
  139. }
  140. }
  141. ui->treeMods->blockSignals(false);
  142. }