cmodlist.h 2.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112
  1. /*
  2. * cmodlist.h, 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. #pragma once
  11. #include <QVariantMap>
  12. #include <QVariant>
  13. #include <QVector>
  14. namespace ModStatus
  15. {
  16. enum EModStatus
  17. {
  18. MASK_NONE = 0,
  19. ENABLED = 1,
  20. INSTALLED = 2,
  21. UPDATEABLE = 4,
  22. MASK_ALL = 255
  23. };
  24. }
  25. class CModEntry
  26. {
  27. // repository contains newest version only (if multiple are available)
  28. QVariantMap repository;
  29. QVariantMap localData;
  30. QVariantMap modSettings;
  31. QString modname;
  32. QVariant getValueImpl(QString value, bool localized) const;
  33. public:
  34. CModEntry(QVariantMap repository, QVariantMap localData, QVariantMap modSettings, QString modname);
  35. // installed and enabled
  36. bool isEnabled() const;
  37. // installed but disabled
  38. bool isDisabled() const;
  39. // available in any of repositories but not installed
  40. bool isAvailable() const;
  41. // installed and greater version exists in repository
  42. bool isUpdateable() const;
  43. // installed
  44. bool isInstalled() const;
  45. // vcmi essential files
  46. bool isEssential() const;
  47. // checks if version is compatible with vcmi
  48. bool isCompatible() const;
  49. // returns true if mod should be visible in Launcher
  50. bool isVisible() const;
  51. // returns true if mod type is Translation
  52. bool isTranslation() const;
  53. // returns true if mod type is Compatibility
  54. bool isCompatibilityPatch() const;
  55. // returns true if this is a submod
  56. bool isSubmod() const;
  57. // see ModStatus enum
  58. int getModStatus() const;
  59. QString getName() const;
  60. // get value of some field in mod structure. Returns empty optional if value is not present
  61. QVariant getValue(QString value) const;
  62. QVariant getBaseValue(QString value) const;
  63. QStringList getDependencies() const;
  64. QStringList getConflicts() const;
  65. static QString sizeToString(double size);
  66. };
  67. class CModList
  68. {
  69. QVector<QVariantMap> repositories;
  70. QVariantMap localModList;
  71. QVariantMap modSettings;
  72. mutable QMap<QString, CModEntry> cachedMods;
  73. QVariantMap copyField(QVariantMap data, QString from, QString to) const;
  74. CModEntry getModUncached(QString modname) const;
  75. public:
  76. virtual void resetRepositories();
  77. virtual void reloadRepositories();
  78. virtual void addRepository(QVariantMap data);
  79. virtual void setLocalModList(QVariantMap data);
  80. virtual void setModSettings(QVariant data);
  81. virtual void modChanged(QString modID);
  82. // returns mod by name. Note: mod MUST exist
  83. const CModEntry & getMod(QString modname) const;
  84. // returns list of all mods necessary to run selected one, including mod itself
  85. // order is: first mods in list don't have any dependencies, last mod is modname
  86. // note: may include mods not present in list
  87. QStringList getRequirements(QString modname);
  88. bool hasMod(QString modname) const;
  89. // returns list of all available mods
  90. QVector<QString> getModList() const;
  91. QVector<QString> getChildren(QString parent) const;
  92. };