modstatemodel.cpp 4.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172
  1. /*
  2. * modstatemodel.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 "modstatemodel.h"
  12. #include "../../lib/filesystem/Filesystem.h"
  13. #include "../../lib/modding/ModManager.h"
  14. ModStateModel::ModStateModel()
  15. : repositoryData(std::make_unique<JsonNode>())
  16. , modManager(std::make_unique<ModManager>())
  17. {
  18. }
  19. ModStateModel::~ModStateModel() = default;
  20. void ModStateModel::setRepositoryData(const JsonNode & repositoriesList)
  21. {
  22. *repositoryData = repositoriesList;
  23. modManager = std::make_unique<ModManager>(*repositoryData);
  24. }
  25. void ModStateModel::reloadLocalState()
  26. {
  27. CResourceHandler::get("initial")->updateFilteredFiles([](const std::string &){ return true; });
  28. modManager = std::make_unique<ModManager>(*repositoryData);
  29. }
  30. const JsonNode & ModStateModel::getRepositoryData() const
  31. {
  32. return *repositoryData;
  33. }
  34. ModState ModStateModel::getMod(QString modName) const
  35. {
  36. assert(modName.toLower() == modName);
  37. return ModState(modManager->getModDescription(modName.toStdString()));
  38. }
  39. template<typename Container>
  40. QStringList stringListStdToQt(const Container & container)
  41. {
  42. QStringList result;
  43. for (const auto & str : container)
  44. result.push_back(QString::fromStdString(str));
  45. return result;
  46. }
  47. QStringList ModStateModel::getAllMods() const
  48. {
  49. return stringListStdToQt(modManager->getAllMods());
  50. }
  51. bool ModStateModel::isModExists(QString modName) const
  52. {
  53. return vstd::contains(modManager->getAllMods(), modName.toStdString());
  54. }
  55. bool ModStateModel::isModInstalled(QString modName) const
  56. {
  57. return isModExists(modName) && getMod(modName).isInstalled();
  58. }
  59. bool ModStateModel::isModSettingEnabled(QString rootModName, QString modSettingName) const
  60. {
  61. return modManager->isModSettingActive(rootModName.toStdString(), modSettingName.toStdString());
  62. }
  63. bool ModStateModel::isModEnabled(QString modName) const
  64. {
  65. return modManager->isModActive(modName.toStdString());
  66. }
  67. bool ModStateModel::isModUpdateAvailable(QString modName) const
  68. {
  69. return getMod(modName).isUpdateAvailable();
  70. }
  71. bool ModStateModel::isModVisible(QString modName) const
  72. {
  73. return getMod(modName).isVisible();
  74. }
  75. QString ModStateModel::getInstalledModSizeFormatted(QString modName) const
  76. {
  77. return QCoreApplication::translate("File size", "%1 MiB").arg(QString::number(getInstalledModSizeMegabytes(modName), 'f', 1));
  78. }
  79. double ModStateModel::getInstalledModSizeMegabytes(QString modName) const
  80. {
  81. return modManager->getInstalledModSizeMegabytes(modName.toStdString());
  82. }
  83. void ModStateModel::doEnableMods(QStringList modList)
  84. {
  85. std::vector<std::string> stdList;
  86. for (const auto & entry : modList)
  87. stdList.push_back(entry.toStdString());
  88. modManager->tryEnableMods(stdList);
  89. }
  90. void ModStateModel::doDisableMod(QString modname)
  91. {
  92. modManager->tryDisableMod(modname.toStdString());
  93. }
  94. bool ModStateModel::isSubmod(QString modname)
  95. {
  96. return modname.contains('.');
  97. }
  98. QString ModStateModel::getTopParent(QString modname) const
  99. {
  100. QStringList components = modname.split('.');
  101. if (components.size() > 1)
  102. return components.front();
  103. else
  104. return "";
  105. }
  106. void ModStateModel::createNewPreset(const QString & presetName)
  107. {
  108. modManager->createNewPreset(presetName.toStdString());
  109. }
  110. void ModStateModel::deletePreset(const QString & presetName)
  111. {
  112. modManager->deletePreset(presetName.toStdString());
  113. }
  114. void ModStateModel::activatePreset(const QString & presetName)
  115. {
  116. modManager->activatePreset(presetName.toStdString());
  117. }
  118. void ModStateModel::renamePreset(const QString & oldPresetName, const QString & newPresetName)
  119. {
  120. modManager->renamePreset(oldPresetName.toStdString(), newPresetName.toStdString());
  121. }
  122. QStringList ModStateModel::getAllPresets() const
  123. {
  124. auto result = modManager->getAllPresets();
  125. return stringListStdToQt(result);
  126. }
  127. QString ModStateModel::getActivePreset() const
  128. {
  129. return QString::fromStdString(modManager->getActivePreset());
  130. }
  131. JsonNode ModStateModel::exportCurrentPreset() const
  132. {
  133. return modManager->exportCurrentPreset();
  134. }
  135. std::tuple<QString, QStringList> ModStateModel::importPreset(const JsonNode & data)
  136. {
  137. std::tuple<QString, QStringList> result;
  138. const auto & [presetName, modList] = modManager->importPreset(data);
  139. return {QString::fromStdString(presetName), stringListStdToQt(modList)};
  140. }