Der neuer Code von Corwin verhinderte neue Einheiten, wenn game.maxunits im XML file nicht gesetzt war (Regel im alten Code war wenn maxunits=0, dann kein Limit). War nicht gut für HSE :-)

This commit is contained in:
Enno Rehling 2005-05-20 22:51:37 +00:00
parent 71296bfced
commit 2fc718b983
2 changed files with 32 additions and 43 deletions

View file

@ -3354,54 +3354,47 @@ ageing(void)
} }
static int static int
maxunits(faction *f) maxunits(const faction *f)
{ {
if(global.unitsperalliance == true) { if (global.unitsperalliance == true) {
faction *f2; faction *f2;
float mult = 1.0; float mult = 1.0;
for(f2 = factions; f2; f2 = f2->next) { for (f2 = factions; f2; f2 = f2->next) {
if(f2->alliance == f->alliance) { if (f2->alliance == f->alliance) {
mult += 0.4f * fspecial(f2, FS_ADMINISTRATOR); mult += 0.4f * fspecial(f2, FS_ADMINISTRATOR);
} }
} }
return (int) (global.maxunits * mult); return (int) (global.maxunits * mult);
} }
return (int) (global.maxunits * return (int) (global.maxunits * (1 + 0.4 * fspecial(f, FS_ADMINISTRATOR)));
(1 + 0.4 * fspecial(f, FS_ADMINISTRATOR)));
} }
static boolean static boolean
checkunitnumber(faction *f) checkunitnumber(const faction *f, int add)
{ {
if(global.unitsperalliance == true) { if (global.maxunits==0) return true;
faction *f2; if (global.unitsperalliance == true) {
int unitsinalliance = 0;
for(f2 = factions; f2; f2 = f2->next) {
if(f->alliance == f2->alliance) {
unitsinalliance += f2->no_units;
}
}
/* if unitsperalliance is true, maxunits returns the /* if unitsperalliance is true, maxunits returns the
number of units allowed in an alliance */ number of units allowed in an alliance */
if(unitsinalliance >= maxunits(f)) { faction *f2;
return false; int unitsinalliance = add;
} else { int maxu = maxunits(f);
return true;
}
}
if(f->no_units >= maxunits(f)) { for (f2 = factions; f2; f2 = f2->next) {
return false; if (f->alliance == f2->alliance) {
unitsinalliance += f2->no_units;
}
if (unitsinalliance > maxu) return false;
} }
return true; return true;
}
return (f->no_units + add < maxunits(f));
} }
static void static void
new_units (void) new_units (void)
{ {
@ -3425,7 +3418,7 @@ new_units (void)
int g, alias; int g, alias;
order ** newordersp; order ** newordersp;
if (checkunitnumber(u->faction) == false) { if (checkunitnumber(u->faction, 1) == false) {
if (global.unitsperalliance == false) { if (global.unitsperalliance == false) {
ADDMSG(&u->faction->msgs, msg_message("too_many_units_in_faction", ADDMSG(&u->faction->msgs, msg_message("too_many_units_in_faction",
"command unit region allowed", "command unit region allowed",

View file

@ -39,6 +39,7 @@ without prior permission by the authors of Eressea.
/* libc includes */ /* libc includes */
#include <assert.h> #include <assert.h>
#include <ctype.h> #include <ctype.h>
#include <limits.h>
#include <string.h> #include <string.h>
static boolean gamecode_enabled = false; static boolean gamecode_enabled = false;
@ -1179,12 +1180,7 @@ parse_main(xmlDocPtr doc)
} }
global.unitsperalliance = xml_bvalue(node, "unitsperalliance", false); global.unitsperalliance = xml_bvalue(node, "unitsperalliance", false);
global.maxunits = xml_ivalue(node, "units", INT_MAX);
property = xmlGetProp(node, BAD_CAST "units");
if (property!=NULL) {
global.maxunits = atoi((const char*)property);
xmlFree(property);
}
property = xmlGetProp(node, BAD_CAST "name"); property = xmlGetProp(node, BAD_CAST "name");
if (property!=NULL) { if (property!=NULL) {