summaryrefslogtreecommitdiffstats
path: root/source/MobCensus.cpp
blob: 4984c53c4e06456e19b5f90f735020f745235f61 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89

#include "Globals.h"  // NOTE: MSVC stupidness requires this to be the same across all modules

#include "MobCensus.h"



cMobCensus::tCapMultipliersMap cMobCensus::CapMultiplierInitializerBeforeCx11()
{
	std::map<cMonster::eFamily,int> toReturn;
	toReturn[cMonster::mfHostile] = 79;
	toReturn[cMonster::mfPassive] = 11;
	toReturn[cMonster::mfAmbient] = 16;
	toReturn[cMonster::mfWater] = 5;
	return toReturn;
}

cMobCensus::tMobSpawnRate cMobCensus::MobSpawnRateInitializerBeforeCx11()
{
	std::map<cMonster::eFamily,int> toReturn;
	toReturn[cMonster::mfHostile] = 1;
	toReturn[cMonster::mfPassive] = 400;
	toReturn[cMonster::mfAmbient] = 400;
	toReturn[cMonster::mfWater] = 400;
	return toReturn;
}

cMobCensus::tCapMultipliersMap& cMobCensus::m_CapMultipliers()
{
	static tCapMultipliersMap* value = new tCapMultipliersMap(CapMultiplierInitializerBeforeCx11());
	return *value;
}

cMobCensus::tMobSpawnRate& cMobCensus::m_SpawnRate()
{
	static tMobSpawnRate* value = new tMobSpawnRate(MobSpawnRateInitializerBeforeCx11());
	return *value;
}

cMobCensus::cMobCensus()
{
}	

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);
}

bool cMobCensus::isCaped(cMonster::eFamily a_MobFamily)
{
	bool toReturn = true;
	const int ratio = 319; // this should be 256 as we are only supposed to take account from chuncks that are in 17x17 from a player
	// but for now, we use all chunks loaded by players. that means 19 x 19 chucks. That's why we use 256 * (19*19) / (17*17) = 319
	// MG TODO : code the correct count	
	tCapMultipliersMap::const_iterator capMultiplier = m_CapMultipliers().find(a_MobFamily);
	if	(
		(capMultiplier != m_CapMultipliers().end()) &&
		(capMultiplier->second * getChunkNb()) / ratio >= m_MobFamilyCollecter.getNumberOfCollectedMobs(a_MobFamily)
		)
	{
		toReturn = false;
	}
	return toReturn;
}

void cMobCensus::CollectSpawnableChunck(cChunk& a_Chunk)
{
	m_EligibleForSpawnChunks.insert(&a_Chunk);
}

int cMobCensus::getChunkNb()
{
	return m_EligibleForSpawnChunks.size();
}

cMobProximityCounter& cMobCensus::getProximityCounter()
{
	return m_ProximityCounter;
}


void cMobCensus::logd()
{
	LOGD((std::string("Hostile mobs : %d") + (isCaped(cMonster::mfHostile)?"(capped)":"")).c_str(),m_MobFamilyCollecter.getNumberOfCollectedMobs(cMonster::mfHostile));
	LOGD((std::string("Ambiant mobs : %d") + (isCaped(cMonster::mfAmbient)?"(capped)":"")).c_str(),m_MobFamilyCollecter.getNumberOfCollectedMobs(cMonster::mfAmbient));
	LOGD((std::string("Water mobs   : %d") + (isCaped(cMonster::mfWater)?  "(capped)":"")).c_str(),m_MobFamilyCollecter.getNumberOfCollectedMobs(cMonster::mfWater));
	LOGD((std::string("Passive mobs : %d") + (isCaped(cMonster::mfPassive)?"(capped)":"")).c_str(),m_MobFamilyCollecter.getNumberOfCollectedMobs(cMonster::mfPassive));
}