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 "CWishList.h"
#include "CAI.h"
#include "CUnitTable.h"
#include "CUnit.h"
#include "CConfigParser.h"
#include "CEconomy.h"
CWishList::CWishList(AIClasses *ai) {
this->ai = ai;
maxWishlistSize = 0;
}
CWishList::~CWishList() {
LOG_II("CWishList::Stats MaxWishListSize = " << maxWishlistSize)
}
void CWishList::push(unitCategory include, unitCategory exclude, Wish::NPriority p) {
std::map<int, CUnit*>::iterator itFac = ai->unittable->factories.begin();
UnitType *fac;
for (;itFac != ai->unittable->factories.end(); ++itFac) {
fac = itFac->second->type;
std::multimap<float, UnitType*> candidates;
ai->unittable->getBuildables(fac, include, exclude, candidates);
if (!candidates.empty()) {
/* Initialize new std::vector */
if (wishlist.find(fac->def->id) == wishlist.end()) {
std::vector<Wish> L;
wishlist[fac->def->id] = L;
}
/* Determine which buildables we can afford */
std::multimap<float, UnitType*>::iterator i = candidates.begin();
int iterations = candidates.size();
//bool affordable = false;
while(iterations >= 0) {
if (ai->economy->canAffordToBuild(fac, i->second))
;//affordable = true;
else
break;
if (i == --candidates.end())
break;
iterations--;
i++;
}
wishlist[fac->def->id].push_back(Wish(i->second, p, include));
unique(wishlist[fac->def->id]);
std::stable_sort(wishlist[fac->def->id].begin(), wishlist[fac->def->id].end());
}
else {
//CUnit *unit = ai->unittable->getUnit(itFac->first);
//LOG_WW("CWishList::push failed for " << (*unit) << " categories: " << ai->unittable->debugCategories(include))
}
}
maxWishlistSize = std::max<int>(maxWishlistSize, wishlist.size());
}
Wish CWishList::top(int factory) {
const UnitDef *udef = ai->cb->GetUnitDef(factory);
return wishlist[udef->id].front();
}
void CWishList::pop(int factory) {
const UnitDef *udef = ai->cb->GetUnitDef(factory);
wishlist[udef->id].erase(wishlist[udef->id].begin());
}
bool CWishList::empty(int factory) {
std::map<int, std::vector<Wish> >::iterator itList;
const UnitDef *udef = ai->cb->GetUnitDef(factory);
itList = wishlist.find(udef->id);
return itList == wishlist.end() || itList->second.empty();
}
void CWishList::unique(std::vector<Wish>& vector) {
std::vector<Wish>::iterator i;
Wish *w = &(vector.back());
for (i = vector.begin(); i != --vector.end(); i++) {
if (i->ut->def->id == w->ut->def->id) {
i->p = (i->p > w->p) ? i->p : w->p;
vector.pop_back();
return;
}
}
}
|