|
|
@ -20,12 +20,10 @@ namespace MWMechanics
|
|
|
|
if(!itemEmpty())
|
|
|
|
if(!itemEmpty())
|
|
|
|
{
|
|
|
|
{
|
|
|
|
mObjectType = mOldItemPtr.getTypeName();
|
|
|
|
mObjectType = mOldItemPtr.getTypeName();
|
|
|
|
mOldItemId = mOldItemPtr.getCellRef().mRefID;
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else
|
|
|
|
else
|
|
|
|
{
|
|
|
|
{
|
|
|
|
mObjectType="";
|
|
|
|
mObjectType="";
|
|
|
|
mOldItemId="";
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
@ -78,17 +76,13 @@ namespace MWMechanics
|
|
|
|
enchantment.mData.mCost = getEnchantPoints();
|
|
|
|
enchantment.mData.mCost = getEnchantPoints();
|
|
|
|
enchantment.mEffects = mEffectList;
|
|
|
|
enchantment.mEffects = mEffectList;
|
|
|
|
|
|
|
|
|
|
|
|
// Create a new item
|
|
|
|
|
|
|
|
MWWorld::ManualRef ref (MWBase::Environment::get().getWorld()->getStore(), mOldItemId, 1);
|
|
|
|
|
|
|
|
const MWWorld::Ptr& newItemPtr = ref.getPtr();
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// Apply the enchantment
|
|
|
|
// Apply the enchantment
|
|
|
|
const ESM::Enchantment *enchantmentPtr = MWBase::Environment::get().getWorld()->createRecord (enchantment);
|
|
|
|
const ESM::Enchantment *enchantmentPtr = MWBase::Environment::get().getWorld()->createRecord (enchantment);
|
|
|
|
newItemPtr.getClass().applyEnchantment(newItemPtr, enchantmentPtr->mId, getGemCharge(), mNewItemName);
|
|
|
|
std::string newItemId = mOldItemPtr.getClass().applyEnchantment(mOldItemPtr, enchantmentPtr->mId, getGemCharge(), mNewItemName);
|
|
|
|
|
|
|
|
|
|
|
|
// Add the new item to player inventory and remove the old one
|
|
|
|
// Add the new item to player inventory and remove the old one
|
|
|
|
store.remove(mOldItemPtr, 1, player);
|
|
|
|
store.remove(mOldItemPtr, 1, player);
|
|
|
|
store.add(newItemPtr, 1, player);
|
|
|
|
store.add(newItemId, 1, player);
|
|
|
|
|
|
|
|
|
|
|
|
if(!mSelfEnchanting)
|
|
|
|
if(!mSelfEnchanting)
|
|
|
|
payForEnchantment();
|
|
|
|
payForEnchantment();
|
|
|
|