December 2014 files
This commit is contained in:
@@ -3,7 +3,7 @@
|
||||
#include "net.minecraft.world.entity.animal.h"
|
||||
#include "DefendVillageTargetGoal.h"
|
||||
|
||||
DefendVillageTargetGoal::DefendVillageTargetGoal(VillagerGolem *golem) : TargetGoal(golem, 16, false, true)
|
||||
DefendVillageTargetGoal::DefendVillageTargetGoal(VillagerGolem *golem) : TargetGoal(golem, false, true)
|
||||
{
|
||||
this->golem = golem;
|
||||
setRequiredControlFlags(TargetGoal::TargetFlag);
|
||||
@@ -13,8 +13,22 @@ bool DefendVillageTargetGoal::canUse()
|
||||
{
|
||||
shared_ptr<Village> village = golem->getVillage();
|
||||
if (village == NULL) return false;
|
||||
potentialTarget = weak_ptr<Mob>(village->getClosestAggressor(dynamic_pointer_cast<Mob>(golem->shared_from_this())));
|
||||
return canAttack(potentialTarget.lock(), false);
|
||||
potentialTarget = weak_ptr<LivingEntity>(village->getClosestAggressor(dynamic_pointer_cast<LivingEntity>(golem->shared_from_this())));
|
||||
shared_ptr<LivingEntity> potTarget = potentialTarget.lock();
|
||||
if (!canAttack(potTarget, false))
|
||||
{
|
||||
// look for bad players
|
||||
if (mob->getRandom()->nextInt(20) == 0)
|
||||
{
|
||||
potentialTarget = village->getClosestBadStandingPlayer(dynamic_pointer_cast<LivingEntity>(golem->shared_from_this() ));
|
||||
return canAttack(potTarget, false);
|
||||
}
|
||||
return false;
|
||||
}
|
||||
else
|
||||
{
|
||||
return true;
|
||||
}
|
||||
}
|
||||
|
||||
void DefendVillageTargetGoal::start()
|
||||
|
||||
Reference in New Issue
Block a user