@ -164,8 +164,6 @@ MWWorld::ContainerStoreIterator MWWorld::InventoryStore::getSlot (int slot)
void MWWorld : : InventoryStore : : autoEquip ( const MWWorld : : Ptr & actor )
void MWWorld : : InventoryStore : : autoEquip ( const MWWorld : : Ptr & actor )
{
{
const MWMechanics : : NpcStats & stats = MWWorld : : Class : : get ( actor ) . getNpcStats ( actor ) ;
TSlots slots_ ;
TSlots slots_ ;
initSlots ( slots_ ) ;
initSlots ( slots_ ) ;
@ -190,10 +188,10 @@ void MWWorld::InventoryStore::autoEquip (const MWWorld::Ptr& actor)
! actor . getRefData ( ) . getLocals ( ) . getIntVar ( actor . getClass ( ) . getScript ( actor ) , " companion " ) ) )
! actor . getRefData ( ) . getLocals ( ) . getIntVar ( actor . getClass ( ) . getScript ( actor ) , " companion " ) ) )
continue ;
continue ;
int testSkill = MWWorld: : Class : : get ( test ) . getEquipmentSkill ( test ) ;
int testSkill = test. getClass ( ) . getEquipmentSkill ( test ) ;
std : : pair < std : : vector < int > , bool > itemsSlots =
std : : pair < std : : vector < int > , bool > itemsSlots =
MWWorld: : Class : : get ( * iter ) . getEquipmentSlots ( * iter ) ;
iter- > getClass ( ) . getEquipmentSlots ( * iter ) ;
for ( std : : vector < int > : : const_iterator iter2 ( itemsSlots . first . begin ( ) ) ;
for ( std : : vector < int > : : const_iterator iter2 ( itemsSlots . first . begin ( ) ) ;
iter2 ! = itemsSlots . first . end ( ) ; + + iter2 )
iter2 ! = itemsSlots . first . end ( ) ; + + iter2 )
@ -210,16 +208,16 @@ void MWWorld::InventoryStore::autoEquip (const MWWorld::Ptr& actor)
{
{
// check skill
// check skill
int oldSkill =
int oldSkill =
MWWorld: : Class : : get ( old ) . getEquipmentSkill ( old ) ;
old. getClass ( ) . getEquipmentSkill ( old ) ;
if ( testSkill ! = - 1 & & oldSkill = = - 1 )
if ( testSkill ! = - 1 & & oldSkill = = - 1 )
use = true ;
use = true ;
else if ( testSkill ! = - 1 & & oldSkill ! = - 1 & & testSkill ! = oldSkill )
else if ( testSkill ! = - 1 & & oldSkill ! = - 1 & & testSkill ! = oldSkill )
{
{
if ( stats. getSkill ( oldSkill ) . getModified ( ) > stats . getSkill ( testSkill ) . getModified ( ) )
if ( actor. getClass ( ) . getSkill ( actor , oldSkill ) > actor . getClass ( ) . getSkill ( actor , testSkill ) )
continue ; // rejected, because old item better matched the NPC's skills.
continue ; // rejected, because old item better matched the NPC's skills.
if ( stats. getSkill ( oldSkill ) . getModified ( ) < stats . getSkill ( testSkill ) . getModified ( ) )
if ( actor. getClass ( ) . getSkill ( actor , oldSkill ) < actor . getClass ( ) . getSkill ( actor , testSkill ) )
use = true ;
use = true ;
}
}
}
}
@ -227,8 +225,8 @@ void MWWorld::InventoryStore::autoEquip (const MWWorld::Ptr& actor)
if ( ! use )
if ( ! use )
{
{
// check value
// check value
if ( MWWorld: : Class : : get ( old ) . getValue ( old ) > =
if ( old. getClass ( ) . getValue ( old ) > =
MWWorld: : Class : : get ( test ) . getValue ( test ) )
test. getClass ( ) . getValue ( test ) )
{
{
continue ;
continue ;
}
}