IBonusBearer.h 2.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647
  1. /*
  2. * IBonusBearer.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 "Bonus.h"
  12. VCMI_LIB_NAMESPACE_BEGIN
  13. class DLL_LINKAGE IBonusBearer
  14. {
  15. public:
  16. //new bonusing node interface
  17. // * selector is predicate that tests if Bonus matches our criteria
  18. IBonusBearer() = default;
  19. virtual ~IBonusBearer() = default;
  20. virtual TConstBonusListPtr getAllBonuses(const CSelector &selector, const CSelector &limit, const std::string &cachingStr = {}) const = 0;
  21. int valOfBonuses(const CSelector &selector, const std::string &cachingStr = {}) const;
  22. bool hasBonus(const CSelector &selector, const std::string &cachingStr = {}) const;
  23. bool hasBonus(const CSelector &selector, const CSelector &limit, const std::string &cachingStr = {}) const;
  24. TConstBonusListPtr getBonuses(const CSelector &selector, const CSelector &limit, const std::string &cachingStr = {}) const;
  25. TConstBonusListPtr getBonuses(const CSelector &selector, const std::string &cachingStr = {}) const;
  26. std::shared_ptr<const Bonus> getBonus(const CSelector &selector) const; //returns any bonus visible on node that matches (or nullptr if none matches)
  27. //Optimized interface (with auto-caching)
  28. int valOfBonuses(BonusType type) const; //subtype -> subtype of bonus;
  29. bool hasBonusOfType(BonusType type) const;//determines if hero has a bonus of given type (and optionally subtype)
  30. int valOfBonuses(BonusType type, BonusSubtypeID subtype) const; //subtype -> subtype of bonus;
  31. bool hasBonusOfType(BonusType type, BonusSubtypeID subtype) const;//determines if hero has a bonus of given type (and optionally subtype)
  32. bool hasBonusFrom(BonusSource source) const;
  33. bool hasBonusFrom(BonusSource source, BonusSourceID sourceID) const;
  34. TConstBonusListPtr getBonusesFrom(BonusSource source) const;
  35. TConstBonusListPtr getBonusesOfType(BonusType type) const;
  36. TConstBonusListPtr getBonusesOfType(BonusType type, BonusSubtypeID subtype) const;
  37. virtual int32_t getTreeVersion() const = 0;
  38. };
  39. VCMI_LIB_NAMESPACE_END