forked from github/server
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:
parent
71296bfced
commit
2fc718b983
2 changed files with 32 additions and 43 deletions
|
@ -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",
|
||||||
|
|
|
@ -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) {
|
||||||
|
|
Loading…
Reference in a new issue