1
0
cuberite-2a/src/MobCensus.cpp

95 lines
2.1 KiB
C++
Raw Normal View History

#include "Globals.h" // NOTE: MSVC stupidness requires this to be the same across all modules
#include "MobCensus.h"
2013-10-18 14:02:53 -04:00
void cMobCensus::CollectMob(cMonster & a_Monster, cChunk & a_Chunk, double a_Distance)
{
m_ProximityCounter.CollectMob(a_Monster, a_Chunk, a_Distance);
m_MobFamilyCollecter.CollectMob(a_Monster);
}
2013-10-18 14:02:53 -04:00
bool cMobCensus::IsCapped(cMonster::eFamily a_MobFamily)
{
const int ratio = 319; // This should be 256 as we are only supposed to take account from chunks that are in 17x17 from a player
2013-10-18 14:02:53 -04:00
// but for now, we use all chunks loaded by players. that means 19 x 19 chunks. That's why we use 256 * (19*19) / (17*17) = 319
// MG TODO : code the correct count
if ((GetCapMultiplier(a_MobFamily) * GetNumChunks()) / ratio >= m_MobFamilyCollecter.GetNumberOfCollectedMobs(a_MobFamily))
{
2013-10-18 14:02:53 -04:00
return false;
}
2013-10-18 14:02:53 -04:00
return true;
}
2013-10-18 14:02:53 -04:00
int cMobCensus::GetCapMultiplier(cMonster::eFamily a_MobFamily)
{
switch (a_MobFamily)
{
case cMonster::mfHostile: return 79;
case cMonster::mfPassive: return 11;
case cMonster::mfAmbient: return 16;
case cMonster::mfWater: return 5;
2013-12-20 10:22:16 -05:00
default:
{
ASSERT(!"Unhandled mob family");
return -1;
}
}
}
2013-10-18 14:02:53 -04:00
void cMobCensus::CollectSpawnableChunk(cChunk & a_Chunk)
{
m_EligibleForSpawnChunks.insert(&a_Chunk);
}
2013-10-18 14:02:53 -04:00
int cMobCensus::GetNumChunks(void)
{
2014-05-08 14:16:35 -04:00
return (int)m_EligibleForSpawnChunks.size();
}
2013-10-18 14:02:53 -04:00
cMobProximityCounter & cMobCensus::GetProximityCounter(void)
{
return m_ProximityCounter;
}
2013-10-18 14:02:53 -04:00
void cMobCensus::Logd()
{
2013-10-18 14:02:53 -04:00
LOGD("Hostile mobs : %d %s", m_MobFamilyCollecter.GetNumberOfCollectedMobs(cMonster::mfHostile), IsCapped(cMonster::mfHostile) ? "(capped)" : "");
LOGD("Ambient mobs : %d %s", m_MobFamilyCollecter.GetNumberOfCollectedMobs(cMonster::mfAmbient), IsCapped(cMonster::mfAmbient) ? "(capped)" : "");
LOGD("Water mobs : %d %s", m_MobFamilyCollecter.GetNumberOfCollectedMobs(cMonster::mfWater), IsCapped(cMonster::mfWater) ? "(capped)" : "");
LOGD("Passive mobs : %d %s", m_MobFamilyCollecter.GetNumberOfCollectedMobs(cMonster::mfPassive), IsCapped(cMonster::mfPassive) ? "(capped)" : "");
}
2013-10-18 14:02:53 -04:00