mirror of
				https://github.com/OpenMW/openmw.git
				synced 2025-10-26 04:26:38 +00:00 
			
		
		
		
	Merge branch 'avoid_get_ref_id_string_for_spell' into 'master'
Do not use ESM::RefId::getRefIdString for spell id (#7291) Closes #7291 See merge request OpenMW/openmw!2856
This commit is contained in:
		
						commit
						5446906b30
					
				
					 10 changed files with 89 additions and 15 deletions
				
			
		|  | @ -409,7 +409,7 @@ namespace MWGui | ||||||
|         mSpellStatus->setProgressPosition(successChancePercent); |         mSpellStatus->setProgressPosition(successChancePercent); | ||||||
| 
 | 
 | ||||||
|         mSpellBox->setUserString("ToolTipType", "Spell"); |         mSpellBox->setUserString("ToolTipType", "Spell"); | ||||||
|         mSpellBox->setUserString("Spell", spellId.getRefIdString()); |         mSpellBox->setUserString("Spell", spellId.serialize()); | ||||||
| 
 | 
 | ||||||
|         // use the icon of the first effect
 |         // use the icon of the first effect
 | ||||||
|         const ESM::MagicEffect* effect = MWBase::Environment::get().getWorld()->getStore().get<ESM::MagicEffect>().find( |         const ESM::MagicEffect* effect = MWBase::Environment::get().getWorld()->getStore().get<ESM::MagicEffect>().find( | ||||||
|  |  | ||||||
|  | @ -296,7 +296,7 @@ namespace MWGui | ||||||
| 
 | 
 | ||||||
|         mSelected->button->setItem(MWWorld::Ptr()); |         mSelected->button->setItem(MWWorld::Ptr()); | ||||||
|         mSelected->button->setUserString("ToolTipType", "Spell"); |         mSelected->button->setUserString("ToolTipType", "Spell"); | ||||||
|         mSelected->button->setUserString("Spell", spellId.getRefIdString()); |         mSelected->button->setUserString("Spell", spellId.serialize()); | ||||||
| 
 | 
 | ||||||
|         // use the icon of the first effect
 |         // use the icon of the first effect
 | ||||||
|         const ESM::MagicEffect* effect = esmStore.get<ESM::MagicEffect>().find(spell->mEffects.mList.front().mEffectID); |         const ESM::MagicEffect* effect = esmStore.get<ESM::MagicEffect>().find(spell->mEffects.mList.front().mEffectID); | ||||||
|  | @ -517,7 +517,7 @@ namespace MWGui | ||||||
|                     break; |                     break; | ||||||
|                 } |                 } | ||||||
|                 case ESM::QuickKeys::Type::Magic: |                 case ESM::QuickKeys::Type::Magic: | ||||||
|                     key.mId = ESM::RefId::stringRefId(button->getUserString("Spell")); |                     key.mId = ESM::RefId::deserialize(button->getUserString("Spell")); | ||||||
|                     break; |                     break; | ||||||
|             } |             } | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -452,13 +452,13 @@ namespace MWGui | ||||||
|         const ESM::Race* race = store.get<ESM::Race>().find(mCurrentRaceId); |         const ESM::Race* race = store.get<ESM::Race>().find(mCurrentRaceId); | ||||||
| 
 | 
 | ||||||
|         int i = 0; |         int i = 0; | ||||||
|         for (const auto& spellpower : race->mPowers.mList) |         for (const ESM::RefId& spellpower : race->mPowers.mList) | ||||||
|         { |         { | ||||||
|             Widgets::MWSpellPtr spellPowerWidget = mSpellPowerList->createWidget<Widgets::MWSpell>( |             Widgets::MWSpellPtr spellPowerWidget = mSpellPowerList->createWidget<Widgets::MWSpell>( | ||||||
|                 "MW_StatName", coord, MyGUI::Align::Default, std::string("SpellPower") + MyGUI::utility::toString(i)); |                 "MW_StatName", coord, MyGUI::Align::Default, std::string("SpellPower") + MyGUI::utility::toString(i)); | ||||||
|             spellPowerWidget->setSpellId(spellpower); |             spellPowerWidget->setSpellId(spellpower); | ||||||
|             spellPowerWidget->setUserString("ToolTipType", "Spell"); |             spellPowerWidget->setUserString("ToolTipType", "Spell"); | ||||||
|             spellPowerWidget->setUserString("Spell", spellpower.getRefIdString()); |             spellPowerWidget->setUserString("Spell", spellpower.serialize()); | ||||||
| 
 | 
 | ||||||
|             mSpellPowerItems.push_back(spellPowerWidget); |             mSpellPowerItems.push_back(spellPowerWidget); | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -315,7 +315,7 @@ namespace MWGui | ||||||
|             "MW_StatName", coord1 + MyGUI::IntSize(coord2.width, 0), MyGUI::Align::Default); |             "MW_StatName", coord1 + MyGUI::IntSize(coord2.width, 0), MyGUI::Align::Default); | ||||||
|         widget->setSpellId(spell->mId); |         widget->setSpellId(spell->mId); | ||||||
|         widget->setUserString("ToolTipType", "Spell"); |         widget->setUserString("ToolTipType", "Spell"); | ||||||
|         widget->setUserString("Spell", spell->mId.getRefIdString()); |         widget->setUserString("Spell", spell->mId.serialize()); | ||||||
|         widget->eventMouseWheel += MyGUI::newDelegate(this, &ReviewDialog::onMouseWheel); |         widget->eventMouseWheel += MyGUI::newDelegate(this, &ReviewDialog::onMouseWheel); | ||||||
| 
 | 
 | ||||||
|         mSkillWidgets.push_back(widget); |         mSkillWidgets.push_back(widget); | ||||||
|  |  | ||||||
|  | @ -66,7 +66,7 @@ namespace MWGui | ||||||
|         toAdd->setSize(mSpellsView->getWidth(), lineHeight); |         toAdd->setSize(mSpellsView->getWidth(), lineHeight); | ||||||
|         toAdd->eventMouseWheel += MyGUI::newDelegate(this, &SpellBuyingWindow::onMouseWheel); |         toAdd->eventMouseWheel += MyGUI::newDelegate(this, &SpellBuyingWindow::onMouseWheel); | ||||||
|         toAdd->setUserString("ToolTipType", "Spell"); |         toAdd->setUserString("ToolTipType", "Spell"); | ||||||
|         toAdd->setUserString("Spell", spell.mId.getRefIdString()); |         toAdd->setUserString("Spell", spell.mId.serialize()); | ||||||
|         toAdd->setUserString("SpellCost", std::to_string(spell.mData.mCost)); |         toAdd->setUserString("SpellCost", std::to_string(spell.mData.mCost)); | ||||||
|         toAdd->eventMouseButtonClick += MyGUI::newDelegate(this, &SpellBuyingWindow::onSpellButtonClick); |         toAdd->eventMouseButtonClick += MyGUI::newDelegate(this, &SpellBuyingWindow::onSpellButtonClick); | ||||||
|         mSpellsWidgetMap.insert(std::make_pair(toAdd, spell.mId)); |         mSpellsWidgetMap.insert(std::make_pair(toAdd, spell.mId)); | ||||||
|  |  | ||||||
|  | @ -286,7 +286,7 @@ namespace MWGui | ||||||
|         else |         else | ||||||
|         { |         { | ||||||
|             widget->setUserString("ToolTipType", "Spell"); |             widget->setUserString("ToolTipType", "Spell"); | ||||||
|             widget->setUserString("Spell", spell.mId.getRefIdString()); |             widget->setUserString("Spell", spell.mId.serialize()); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         widget->setUserString(sSpellModelIndex, MyGUI::utility::toString(index)); |         widget->setUserString(sSpellModelIndex, MyGUI::utility::toString(index)); | ||||||
|  |  | ||||||
|  | @ -227,7 +227,7 @@ namespace MWGui | ||||||
|                     ToolTipInfo info; |                     ToolTipInfo info; | ||||||
| 
 | 
 | ||||||
|                     const ESM::Spell* spell = MWBase::Environment::get().getWorld()->getStore().get<ESM::Spell>().find( |                     const ESM::Spell* spell = MWBase::Environment::get().getWorld()->getStore().get<ESM::Spell>().find( | ||||||
|                         ESM::RefId::stringRefId(focus->getUserString("Spell"))); |                         ESM::RefId::deserialize(focus->getUserString("Spell"))); | ||||||
|                     info.caption = spell->mName; |                     info.caption = spell->mName; | ||||||
|                     Widgets::SpellEffectList effects; |                     Widgets::SpellEffectList effects; | ||||||
|                     for (const ESM::ENAMstruct& spellEffect : spell->mEffects.mList) |                     for (const ESM::ENAMstruct& spellEffect : spell->mEffects.mList) | ||||||
|  |  | ||||||
|  | @ -179,14 +179,14 @@ namespace ESM | ||||||
| 
 | 
 | ||||||
|         TEST(ESMRefIdTest, canBeUsedAsMapKeyWithLookupByStringView) |         TEST(ESMRefIdTest, canBeUsedAsMapKeyWithLookupByStringView) | ||||||
|         { |         { | ||||||
|             const std::map<ESM::RefId, int, std::less<>> map({ { ESM::RefId::stringRefId("a"), 42 } }); |             const std::map<RefId, int, std::less<>> map({ { RefId::stringRefId("a"), 42 } }); | ||||||
|             EXPECT_EQ(map.count("A"), 1); |             EXPECT_EQ(map.count("A"), 1); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         TEST(ESMRefIdTest, canBeUsedAsLookupKeyForMapWithStringKey) |         TEST(ESMRefIdTest, canBeUsedAsLookupKeyForMapWithStringKey) | ||||||
|         { |         { | ||||||
|             const std::map<std::string, int, std::less<>> map({ { "a", 42 } }); |             const std::map<std::string, int, std::less<>> map({ { "a", 42 } }); | ||||||
|             EXPECT_EQ(map.count(ESM::RefId::stringRefId("A")), 1); |             EXPECT_EQ(map.count(RefId::stringRefId("A")), 1); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         TEST(ESMRefIdTest, stringRefIdIsNotEqualToFormId) |         TEST(ESMRefIdTest, stringRefIdIsNotEqualToFormId) | ||||||
|  | @ -196,7 +196,7 @@ namespace ESM | ||||||
|             EXPECT_NE(stringRefId, formIdRefId); |             EXPECT_NE(stringRefId, formIdRefId); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         struct ESMRefIdToStringTest : TestWithParam<std::pair<ESM::RefId, std::string>> |         struct ESMRefIdToStringTest : TestWithParam<std::pair<RefId, std::string>> | ||||||
|         { |         { | ||||||
|         }; |         }; | ||||||
| 
 | 
 | ||||||
|  | @ -213,12 +213,12 @@ namespace ESM | ||||||
|             { RefId::stringRefId(std::string({ 'a', 0, -1, '\n', '\t' })), { 'a', 0, -1, '\n', '\t' } }, |             { RefId::stringRefId(std::string({ 'a', 0, -1, '\n', '\t' })), { 'a', 0, -1, '\n', '\t' } }, | ||||||
|             { RefId::formIdRefId(42), "42" }, |             { RefId::formIdRefId(42), "42" }, | ||||||
|             { RefId::generated(42), "42" }, |             { RefId::generated(42), "42" }, | ||||||
|             { RefId::index(ESM::REC_ARMO, 42), "ARMO, 42" }, |             { RefId::index(REC_ARMO, 42), "ARMO, 42" }, | ||||||
|         }; |         }; | ||||||
| 
 | 
 | ||||||
|         INSTANTIATE_TEST_SUITE_P(ESMRefIdToString, ESMRefIdToStringTest, ValuesIn(toStringParams)); |         INSTANTIATE_TEST_SUITE_P(ESMRefIdToString, ESMRefIdToStringTest, ValuesIn(toStringParams)); | ||||||
| 
 | 
 | ||||||
|         struct ESMRefIdToDebugStringTest : TestWithParam<std::pair<ESM::RefId, std::string>> |         struct ESMRefIdToDebugStringTest : TestWithParam<std::pair<RefId, std::string>> | ||||||
|         { |         { | ||||||
|         }; |         }; | ||||||
| 
 | 
 | ||||||
|  | @ -244,9 +244,61 @@ namespace ESM | ||||||
|             { RefId::stringRefId(std::string({ 'a', 0, -1, '\n', '\t' })), "String{a\\x0\\xFF\\xA\\x9}" }, |             { RefId::stringRefId(std::string({ 'a', 0, -1, '\n', '\t' })), "String{a\\x0\\xFF\\xA\\x9}" }, | ||||||
|             { RefId::formIdRefId(42), "FormId{42}" }, |             { RefId::formIdRefId(42), "FormId{42}" }, | ||||||
|             { RefId::generated(42), "Generated{42}" }, |             { RefId::generated(42), "Generated{42}" }, | ||||||
|             { RefId::index(ESM::REC_ARMO, 42), "Index{ARMO, 42}" }, |             { RefId::index(REC_ARMO, 42), "Index{ARMO, 42}" }, | ||||||
|         }; |         }; | ||||||
| 
 | 
 | ||||||
|         INSTANTIATE_TEST_SUITE_P(ESMRefIdToDebugString, ESMRefIdToDebugStringTest, ValuesIn(toDebugStringParams)); |         INSTANTIATE_TEST_SUITE_P(ESMRefIdToDebugString, ESMRefIdToDebugStringTest, ValuesIn(toDebugStringParams)); | ||||||
|  | 
 | ||||||
|  |         template <class T> | ||||||
|  |         RefId generateRefId(); | ||||||
|  | 
 | ||||||
|  |         template <> | ||||||
|  |         RefId generateRefId<EmptyRefId>() | ||||||
|  |         { | ||||||
|  |             return RefId(); | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         template <> | ||||||
|  |         RefId generateRefId<StringRefId>() | ||||||
|  |         { | ||||||
|  |             return RefId::stringRefId("StringRefId"); | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         template <> | ||||||
|  |         RefId generateRefId<FormIdRefId>() | ||||||
|  |         { | ||||||
|  |             return RefId::formIdRefId(42); | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         template <> | ||||||
|  |         RefId generateRefId<GeneratedRefId>() | ||||||
|  |         { | ||||||
|  |             return RefId::generated(13); | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         template <> | ||||||
|  |         RefId generateRefId<IndexRefId>() | ||||||
|  |         { | ||||||
|  |             return RefId::index(REC_BOOK, 7); | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         template <class T> | ||||||
|  |         struct ESMRefIdSerializeDeserializeTest : Test | ||||||
|  |         { | ||||||
|  |         }; | ||||||
|  | 
 | ||||||
|  |         TYPED_TEST_SUITE_P(ESMRefIdSerializeDeserializeTest); | ||||||
|  | 
 | ||||||
|  |         TYPED_TEST_P(ESMRefIdSerializeDeserializeTest, serializeThenDeserializeShouldProduceSameValue) | ||||||
|  |         { | ||||||
|  |             const RefId refId = generateRefId<TypeParam>(); | ||||||
|  |             EXPECT_EQ(RefId::deserialize(refId.serialize()), refId); | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         REGISTER_TYPED_TEST_SUITE_P(ESMRefIdSerializeDeserializeTest, serializeThenDeserializeShouldProduceSameValue); | ||||||
|  | 
 | ||||||
|  |         using RefIdTypeParams = Types<EmptyRefId, StringRefId, FormIdRefId, GeneratedRefId, IndexRefId>; | ||||||
|  | 
 | ||||||
|  |         INSTANTIATE_TYPED_TEST_SUITE_P(RefIdTypes, ESMRefIdSerializeDeserializeTest, RefIdTypeParams); | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  |  | ||||||
|  | @ -177,4 +177,20 @@ namespace ESM | ||||||
|     { |     { | ||||||
|         return std::visit(Contains{ subString }, mValue); |         return std::visit(Contains{ subString }, mValue); | ||||||
|     } |     } | ||||||
|  | 
 | ||||||
|  |     std::string RefId::serialize() const | ||||||
|  |     { | ||||||
|  |         std::string result(sizeof(mValue), '\0'); | ||||||
|  |         std::memcpy(result.data(), &mValue, sizeof(mValue)); | ||||||
|  |         return result; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     ESM::RefId RefId::deserialize(std::string_view value) | ||||||
|  |     { | ||||||
|  |         if (value.size() != sizeof(ESM::RefId::mValue)) | ||||||
|  |             throw std::runtime_error("Invalid value size to deserialize: " + std::to_string(value.size())); | ||||||
|  |         ESM::RefId result; | ||||||
|  |         std::memcpy(&result.mValue, value.data(), sizeof(result.mValue)); | ||||||
|  |         return result; | ||||||
|  |     } | ||||||
| } | } | ||||||
|  |  | ||||||
|  | @ -48,6 +48,9 @@ namespace ESM | ||||||
|     public: |     public: | ||||||
|         const static RefId sEmpty; |         const static RefId sEmpty; | ||||||
| 
 | 
 | ||||||
|  |         // Constructs RefId from a string containing byte by byte copy of RefId::mValue.
 | ||||||
|  |         static ESM::RefId deserialize(std::string_view value); | ||||||
|  | 
 | ||||||
|         // Constructs RefId from a string using a pointer to a static set of strings.
 |         // Constructs RefId from a string using a pointer to a static set of strings.
 | ||||||
|         static RefId stringRefId(std::string_view value); |         static RefId stringRefId(std::string_view value); | ||||||
| 
 | 
 | ||||||
|  | @ -112,6 +115,9 @@ namespace ESM | ||||||
|         // Otherwise returns false.
 |         // Otherwise returns false.
 | ||||||
|         bool contains(std::string_view subString) const; |         bool contains(std::string_view subString) const; | ||||||
| 
 | 
 | ||||||
|  |         // Copy mValue byte by byte into a string. Use result only during within the same process.
 | ||||||
|  |         std::string serialize() const; | ||||||
|  | 
 | ||||||
|         friend constexpr bool operator==(const RefId& l, const RefId& r) { return l.mValue == r.mValue; } |         friend constexpr bool operator==(const RefId& l, const RefId& r) { return l.mValue == r.mValue; } | ||||||
| 
 | 
 | ||||||
|         bool operator==(std::string_view rhs) const; |         bool operator==(std::string_view rhs) const; | ||||||
|  |  | ||||||
		Loading…
	
		Reference in a new issue